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CHAPTER 1 



INTRODUCTION 



The Seattle Computer DiskMaster™ gives system designers a 
flexible, high performance floppy disk controller for the 
S-100 (IEE-696) bus. The DiskMaster supports both 8-inch 
and 5.25-inch floppy disk drives. 

As many as four 8-inch and four 5.25-inch drives, in any 
combination, may be controlled simultaneously by a single 
DiskMaster. This makes it easy to transfer data between 8- 
inch and 5.25-inch disks v/ithin the sytem. 

A patent-pending digital data separator design provides 
unsurpassed data recovery reliability. This digital 
technique enhances data recovery reliability over older, 
less accurate analog techniques. As a result, the 
DiskMaster has a wider tolerance for the varying read/write 
data speeds of floppy disks from other systems. 
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Introduction 



FEATURES 



Handles up to eight disk drives, four 8-inch and four 
5.25-inch. 

Physically and electrically separate connectors for 8- 
inch and 5.25-inch disk drives to eliminate crosstalk 
and overloading of signal drivers. 

Configuration header to handle the different pin 
arrangement of 8-inch drives. 

Complete automatic hardware support for disk drives 
with voice-coil head positioners. 

Complete automatic hardware support for disk drives 
with spindle-motor control. 

A breakthrough in data separator design for unsurpassed 
data-recovery reliability (patent pending). 

Based on the Western Digital 1793 disk controller chip. 
(The data sheet for the 1793 chip is found in Appendix 
A.) 

Full compliance with the IEEE-696 standard. 

Direct Memory Access capability when combined with 
Seattle Computer's Direct Memory Access Controller 
board. 

Allows easy transfer of data and software between 8- 
inch drives and 5.25-inch drives. 



CHAPTER 2. SWITCH AND JUMPER SETTINGS 



Switch and jumper locations are shown on this page and the 
next page. 
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DISK MASTER 




DiskMaster Switch Locations 



Switch and Jumper Settings 




DiskMaster jumper Locations 



Switch and Jumper Settings 



BUS INTERFACE SWITCHES AND JUMPERS 



PORT ADDRESS Switch 

The DiskMaster requires six I/O ports that are grouped 
consecutively starting on any 8-port boundary called the 
BASE. The BASE is selected using the top five positions of 
the PORT ADDRESS switch. These top five positions are 
labeled A7-A3 and correspond to address lines A7-A3 on t;he 
bus. The bottom three positions of ::he PORT ADDRESS switch 
are not used. 



Switch settings 


I/O port 




address base 


A7 A6 A5 A4 A3 







00 hex 


1 


08 hex 


1 


10 hex 


11 


18 hex 


10 


20 hex 


10 1 


2 8 hex 


110 


3 hex 


111 


3 8 hex 


10 


40 hex 


10 1 


4 8 hex 


10 10 


50 hex 


10 11 


58 hex 


110 


60 hex 


110 1 


•5 8 hex 


1110 


70 hex 


1111 


7 8 hex 


10 


80 hex 


10 1 


88 hex 


10 10 


90 hex 


10 11 


9 8 hex 


10 10 


A0 hex 


10 10 1 


A8 hex 


10 110 


B0 hex 


10 111 


B8 hex 


110 


CO hex 


110 1 


C8 hex 


110 10 


DO hex 


110 11 


D8 hex 


1110 


E0 hex* 


1110 1 


E8 hex 


11110 


F0 hex 


11111 


F8 hex 


*BASE address used by £ 


Seattle Computer 


I/O systems 





Switch and Jumper Settings 



INTERRUPT jumper 

Interrupts from the DiskMaster can be sent to any of the 
eight Vectored interrupt lines VI0-VI7 or directly to the 
INT line for systems without interrupt controllers. Place 
the blue shunt over one of the nine vertical pairs of pins 
corresponding to interrupt lines VI0-VI7 or INT. 

If none of the interrupt lines should be used, put the shunt 
on any two of the pins in the upper row. 



WAIT Jumper 

This jumper selects whether or not the DiskMaster asks for 
wait-states when the CPU talks to the 1793 disk controller 
chip. The WAIT jumper should be in the ON position for all 
CPUs faster than a 2-MHz 8080 or Z80. With the WAIT jumper 
in the ON position, the number of wait states asked for 
depends on the CPU speed: the faster the CPU's clock, the 
more wait-states will be requested. 



Switch and jumper Settings 

The following instructions are only necessary if you have a 
DMA controller in your system. 

DMA PRIORITY Switch 

This switch selects the DMA priority to which the Disk 
Master will respond. Since the DMA controller is not 
located on the DiskMaster board, the DiskMaster monitors 
the S-100 bus to determine when a DMA cycle is being run for 
it. The DMA priority lines are used to determine when the 
DiskMaster's DMA controller (one of up to sixteen possible 
DMA controllers) is active. The DMA PRIORITY switches are 
labeled DMA 0-3 on the board to the left of the switch and 1 
and above the switch. 



Switch settings 








DMA DMA DMA DMA 


priority 


Priority 




3 2 1 


(hex) 


(decimal) 










Lowest priority 


1 


1 


1 




10 


2 


2 




11 


3 


3 




10 


4 


4 




10 1 


5 


5 




110 


6 


6 




111 


7 


7 




10 


8 


8 




10 1 


9 


9 




10 10 


A 


10 




10 11 


B 


11 




110 


C 


12 




110 1 


D 


13 




1110 


E 


14 ▼ 


1111 


F 


15 Highest 


priority 



DMA Jumper 

The DiskMaster sends DMA requests to the Direct Memory 
Access Controller board using one of the NDEF pins of 
the S-100 bus. This jumper selects which pin is used. 



CHI 
CH2 



Pin 65 
Pin 66 



Switch and Jumper Settings 



DISK INTERFACE JUMPERS AND HEADERS 



AUTO MOT/SM AUTO/ON Jumper 

This jumper lets the DiskMaster know which drives have 
spindle motors that are under its control. This is a four- 
position jumper; To choose one of the three settings, place 
the blue shunt over the jumpers pins as shown below. 



AUTO MOT 

SM AUTO 
AUTO ON 



SM AUTO 

SM AUTO 
AUTO ON 



ON 

SM AUTO 
AUTO^^ON 



DiskMaster controls motors of both 
8-inch and 5.25-inch drives. Place the 
shunt over the two leftmost jumper 
pins. 

DiskMaster controls 5.25-inch 
spindle motors; 8-inch spindle motors 
are assumed to be always on. Place the 
shunt over the two center jumper pins. 

Spindle motors of both 8-inch and 
5.25-inch drives are assumed to be 
always on. Place the shunt over the 
two rightmost jumper pins. 



LARGE MOT ON Jumper 

This jumper controls the polarity of the MOTOR ON signal 
going to the 8-inch disk drives. Most standard-height 
8-inch drives have AC spindle motors that cannot be turned 
on and off, so the setting of this jumper is irrelevant when 
using these drives. 



LO 



Active-low motor-on (PerSci drives) 



HI 



Active-high motor-on (Tandon drives) 



MOT ON jumper 

This jumper selects how long the DiskMaster waits for the 
spindle motors to come up to speed. 



F 
S 



1/2 second 
1 second 



Switch and jumper Settings 



MOTOR OFF DELAY Jumper 



This jumper selects how long the DiskMaster will keep the 
spindle motors going after the disk heads have been 
unloaded. 

F 7.5 seconds 

S 15 seconds 



HEAD LOAD Jumper 

This jumper selects whether 8-inch drives use the HEAD 
LOAD signal or the DRIVE SELECT signal to load the heads. 

HL Drives use HEAD LOAD signal 

DS Drives use DRIVE SELECT signal 

FAST SEEK Jumper 

This jumper selects whether the 8-inch drives have standard 
stepper motor head positioners or voice coil head 
positioners. 

ON Voice coil positioner 

OFF Stepper motor positioner 

PRECOMP Jumper 

This jumper selects whether write precompensation is 
turned on and off by the 1793 disk controller chip using the 
TG43 signal, or whether write precompensation is enabled by 
a bit in the Auxiliary Command port. If the 1793 controls 
write precompensation, it will be turned on for all tracks 
beyond track 43. Write compensation is not used with 
single-density. 

No precompensation is required for a Seattle Computer system 
with Mitsubishi drives. 

PROG Write precompensation controlled by 
Auxiliary Command port. 

AUTO Write precompensation controlled by 1793's 
TG43 signal. 



Switch and Jumper Settings 



PIN 18 Jumper 

This jumper selects whether pin 18 of the 50-pin connector 
for 8-inch drives are used for head load for for spindle 
motor control. Mitsubishi half-height drives use this line 
for motor control; most other drives ignore the signal or 
use it for head load. 



MOT 



Send HEAD LOAD signal to pin 18 
Send MOTOR ON signal to pin 18 



8-Inch Drive Configuration Header 

This sixteen-pin socket is found in location J3 (between 
IC17 and IC18). It can be used to re-arrange the signals on 
the 50-pin connector for the 8-inch drives (this is required 
for PerSci drives). 



J3 
connector 

Signals from Pin Pin Jl 50-pin 
disk controller no. no. connector 



RESTORE 

DISK CHANGE 

SIDE SELECT 

TG43 

DRIVE SELECT 3 

HEAD LOAD 

DRIVE SELECT 4 



16 
15 
14 
13 
12 
11 
10 
9 



pin 12 
pin 14 
pin 2 
pin 30 
pin 18 
pin 32 
pin 4 



The signals for the standard drive are shown below, along 
with the signals as rearranged for the PerSci drive. 



J3 
Standard drive) 



J3 
(PerSci drive) 
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CHAPTER 3. I/O PORTS 



The DiskMaster uses a total of six I/O ports for 
communication with the CPU. These six ports can be set on 
any eight-port boundary called the BASE. See the 
description of how to select the BASE under "PORT ADDRESS 
Switch" in Section 2. 

The six I/O ports are used as follows: 



BASE+0 - 1793 Command/Status 

register 
BASE+1 - 1793 Track register 
BASE+2 - 1793 Sector register 
BASE+3 - 1793 Data register 
BASE+4 - Auxiliary Command/Status 

port 
BASE+5 - Wait Synchronization port 



See the Western 
Digital data sheet 
in Appendix A 



Described below 



The 1793 uses the first four ports. For more information, 
refer to the Western Digital 1793 data sheet in Appendix A. 



AUXILIARY COMMAND PORT 

The Wait Synchronization I/O port is BASE+4 (see the 
description of how to select the BASE under "PORT ADDRESS 
Switch" in Section 2. 

The bits of the auxiliary command port are: 



Bit 7 


Bit 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 


DMA 
write 


DMA 
enable 


Pre- 
comp 
enable 


Small 
drive 


Double 
density 


Side 


DS1 


DSO 



restore 



DMA WRITE Bit 



Bit 7 controls the DMA direction. The DMA direction refers 
to the direction of the memory access, not the disk access. 
DMA WRITE should be low when DMA ENABLE is low; otherwise 
RESTORE will be activated (see "RESTORE" below). 



Bit 7=0 
= . 1 



Read memory (write disk) 
Write memory (read disk) 
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I/O Ports 



DMA ENABLE Bit 

Bit 6 controls whether DMA requests are passed to the DMA 
controller and whether the DiskMaster responds to DMA 
cycles on the bus. 

To turn off DMA, be sure to turn off both DMA ENABLE 
and DMA WRITE; otherwise RESTORE will be activated (see 
"RESTORE Function" below) . 



Bit 6=0 



= 1 



DMA requests are not sent to the DMA 
control ler; DiskMaster ignores DMA 
cycles on the bus. 

DMA requests are sent to the DMA 
controller; DiskMaster responds to DMA 
cycles on the bus. 



RESTORE Function 

The RESTORE function for PerSci drives is activated by 
setting setting bits 6 and 7 as follows: 

Bit 6=0 

Bit 7=1 

If you do not have PerSci drives, all RESTORE does is load 
the head of the selected drive. This can be a handy way to 
keep the head loaded to perform head alignment or other disk 
drive maintenance. 



PRECOMP ENABLE Bit 



Bit 5 controls whether or not write precompensation is used 
when writing to double-density disks. it also controls the 
low WRITE CURRENT CURRENT or TRACK GREATER THAN 43 (TG43) 
signal to 8-inch drives. If the PRECOMP jumper (see "Disk 
Interface Jumpers and Headers") is in the AUTO position this 
bit does nothing: write precompensation and write current 
are controlled by the TG43 signal from the 1793 disk 
controller chip. 



Bit 5=0 



= 1 



Disable precompensation 
Enable precompensation 
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I/O Ports 



SMALL DRIVE Bit 

Bit 4 selects whether a 5.25-inch drive or an 8-inch drive 
is being used. When 5.25-inch drives are selected, the 8- 
inch drive selects are disabled, and vice-versa. It is this 
feature which allows having four 8-inch drives and four 
5.25-inch drives connected to the DiskMaster at the same 
time. 



Bit 4=0 
= 1 



8-inch drive 
5.25-inch drive 



DOUBLE- DENSITY Bit 

Bit 3 selects single- or double-density operation. 
Bit 3=0 Single-density 
= 1 Double-density 

SIDE Bit 

Bit 2 selects side or 1 of double-sided disks. 
Bit 2=0 Side 
= 1 Side 1 

DS1 and DSO BITS 

Bit 1 (DS1) and bit (DSO) select one of four drives of 
5.25-inch or 8-inch size. 



DS1 


DSO 


Drive 


(bit 1) 


(bit 0) 


selected 








1 





1 


2 


1 





3 


1 


1 


4 
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I/O Ports 

AUXILIARY STATUS PORT 

The bits of the auxiliary status port are described below. 



Bit 7 


Bit 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 


Disk 
change 


Two- 
sided 


Head 
load 


X 


X 


X 


X 


Interrupt 
request 



X = Undefined bits with no particular value, 



DISK CHANGE Bit 

Many Shugart-type 8-inch disk drives provide a Disk Change 
signal on pin 12 of the 50-pin connector which can be read 
using this status bit. If the disk has been changed, the 
Disk Change bit (bit 7) will be low. 



TWO-SIDED/SEEK COMPLETE Bit 

If your 8-inch drives are standard Shugart-type double-sided 
drives, there is probably a TWO-SIDED signal on pin 10 of 
the 50-pin connector which can be read using this status 
bit. When a double-sided disk is used, this bit (bit 6) 
will be high. 

If your 8-inch drives are perSci drives, the state of the 
Seek Complete signal can be read using this bit. This bit 
will be high when the seek is completed. 

HEAD LOAD Bit 

Bit 5 will be high when the disk drive head is loaded 
(including a head-load forced by RESTORE). 



INTERRUPT REQUEST Bit 

The state of the 1793's interrupt request pin can be read 
using bit 0. If this bit is high, the disk controller is 
requesting an interrupt. 
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I/O Ports 



WAIT SYNCHRONIZATION PORT 



The Wait Synchronization port performs the same function as 
the Auxiliary Command/Status port. The only exception is 
that any access of this port holds the CPU in wait states 
until either interrupt Request or Data Request from the 1793 
disk controller chip become active. This port is usually 
used to make the CPU wait until the 1793 disk control ler is 
ready to transfer data in non-DMA systems. 

The Wait Synchronization I/O port is BASE+5 (see the 
description of how to select the BASE under "PORT ADDRESS 
Switch" in Section 2). 
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I/O Ports 
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APPENDIX A. WESTERN DIGITAL DATA SHEET 



WESTERN DIGITAL 

CORPORATION 

FD179X-02 
Floppy Disk Formatter/Controller Family 



FEATURES 

• TWO VFO CONTROL SIGNALS - RG & VFOE 

• SOFT SECTOR FORMAT COMPATIBILITY 

• AUTOMATIC TRACK SEEK WITH VERIFICATION 

• ACCOMMODATES SINGLE AND DOUBLE DENSITY 
FORMATS 

IBM 3740 Single Density (FM) 
IBM System 34 Double Density (MFM) 
3 Noh IBM Format for Increased Capacity 

• READ MODE 

Single/Multiple Sector Read with Automatic Search or 

Entire Track Read 
Selectable 128, 256, 512 or 1024 Byte Sector Lengths 

• WRITE MODE 

Single/Multiple Sector Write with Automatic Sector 

Search 
Entire Track Write for Diskette Formatting 

• SYSTEM COMPATIBILITY 

Double Buffering of Data 8 Bit Bi-Directional Bus for 

Data, Control and Status 
DMA or Programmed Data Transfers 
All Inputs and Outputs are TTL Compatible 
On-Chip Track and Sector Registers/Comprehensive 

Status Information 



• PROGRAMMABLE CONTROLS 
Selectable Track to Track Stepping Time 
Side Select Compare 

• INTERFACES TO WD1 691 DATA SEPARATOR 

• WINDOW EXTENSION 

• INCORPORATES ENCODING/DECODING AND 
ADDRESS MARK CIRCUITRY 

• FD1792/4 IS SINGLE DENSITY ONLY 

• FD1795/7 HAS A SIDE SELECT OUTPUT 

179X-02 FAMILY CHARACTERISTICS 



APPLICATIONS 

8" FLOPPY AND 5Va "MINI FLOPPY CONTROLLER 
SINGLE OR DOUBLE DENSITY 
CONTROLLER/ FORMATTER 



-n 

o 

.^ 

<o 
X 

o 
ro 



FEATURES 


1791 


1792 


1793 


1794 


1795 


1797 


Single Density (FM) 


X 


X 


X 


X 


X 


X 


Double Density (MFM) 


X 




X 




X 


X 


True Data Bus 






X 


X 




X 


Inverted Data Bus 


X 


X 






X 




Write Precomp 


X 


X 


X 


X 


X 


X 


Side Selection Output 










X 


X 



NC 

wE 

■ ■ BE 
*o 
*, 

••DALO 

5al"T 
daT? 
dalI 

DAL4 

oaTs 
PaTS 
oalT 

STEP 

DIHC 

EARLY 

LATE 

(GND)Vss 



~zy 



~\ V DD (+ 12VI 

I] INTRO 
"1 DRO 

WPRT 

IP 

TROO 



~1 WF/VFOE 
1 READY 

WD 
"1 WG 
1 TG43 
1 HLO 
"] RAW READ 

RCLK 

3 • 

~] CLK 
1 HLT 
~i TEST 
J V.„C5V> 



cc" 



•1791/3 = RG 1795/7= SSO 
•1793/7 TRUE BUS 
•1792/4 OPEN 

PIN CONNECTIONS 



<c 


DATA (8) 


,> 




A0 




A1 




cs 




RE 






WE 






MR 





FLOPPY DISK 
CONTROLLER 
FORMATTER 




FD179X SYSTEM BLOCK DIAGRAM 
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Western Digital Data Sheet 



PIN OUTS 



•"J 
CO 

X 

6 
10 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


1 
19 


NO CONNECTION 


NC 
MR 


Pin 1 is internally connected to a back bias generator and 
must be left open by the user. 

A logic low (50 microseconds min.) on this input resets the 
device and loads HEX 03 into the command register. The Not 
Ready (Status Bit 7) is reset during MR ACTIVE. When MR is 
brought to a logic high a RESTORE Command is executed, 
regardless of the state of the Ready signal from the drive. 
Also, HEX 01 is loaded into sector register. 


MASTER RESET 


20 


POWER SUPPLIES 


Vss 


Ground 


21 




Vcc 


+ 5V±5% 


, 40 




Vdd 


+ 12V±5% 


COMPUTE 
2 

3 

4 


R INTERFACE 


WE 
CS 
RE 


A logic low on this input gates data on the DAL into the 
selected register when CS is low. 

A logic low on this input selects the chip and enables 
computer communication with the device. 

A logic low on this input controls the placement of data from a 
selected register on the DAL when CS is low. 


WRITE ENABLE 


CHIP SELECT 


READ ENABLE 


5,6 


REGISTER SELECT LINES 


A0,A1 


These inputs select the register to receive/transfer data on the 
DAL lines under RE and WE control: 

CS A1 A0 RE WE 


7-14 






Status Reg Command Reg 
1 Track Reg Track Reg 
1 Sector Reg Sector Reg 
1 1 Data Reg Data Reg 

Eight bit Bidirectional bus used for transfer of data, control, 
and status. This bus is receiver enabled by WE or transmitter 
enabled by RE. Each line will drive 1 standard TTL load. 


DATA ACCESS LINES 


DAL0-DAL7 


24 


CLOCK 


CLK 


This input requires a free-running 50% duty cycle square wave 
clock for internal timing reference, 2 MHz ± 1% for 8" drives, 
1 MHz ±1% for mini-floppies. 


38 


DATA REQUEST 


DRQ 


This open drain output indicates that the DR contains 
assembled data in Read operations, or the DR is empty in 
Write operations. This signal is reset when serviced by the 
computer through reading or loading the DR in Read or Write 
operations, respectively. Use 10K pull-up resistor to +5. 


39 
FLOPPY D 


INTERRUPT REQUEST 
ISK INTERFACE: 


INTRQ 


This open drain output is set at the completion of any com- 
mand and is reset when the STATUS register is read or the 
command register is written to. Use 10K pull-up resistor to 
+ 5. 


15 


STEP 


STEP 


The step output contains a pulse for each step. 


16 


DIRECTION 


DIRC 


Direction Output is active high when stepping in, active low 
when stepping out. 


17 


EARLY 


EARLY 


Indicates that the WRITE DATA pulse occuring while Early is 
active (high) should be shifted early for write precom- 
pensation. 


18 


LATE 


LATE 


Indicates that the write data pulse occurring while Late is 
active (high) should be shifted late for write precompensation. 
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Western Digital Data Sheet 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


22 


TEST 


TEST 


This input is used for testing purposes only and should be tied 
to + 5V or left open by the user unless interfacing to voice coil 
actuated steppers. 


23 


HEAD LOAD TIMING 


HLT 


When a logic high is found on the HLT input the head is 
assumed to be engaged. It is typically derived from a 1 shot 
triggered by HLD. 


25 


READ GATE 
(1791,1792,1793,1794) 


RG 


This output is used for synchronization of external data 
separators. The output goes high after two Bytes of zeros in 
single density, or 4 Bytes of either zeros or ones in double 
density operation. 


25 


SIDE SELECT OUTPUT 
(1795, 1797) 


SSO 


The logic level of the Side Select Output is directly controlled 
by the 'S' flag in Type II or III commands. When U = 1, SSO is 
set to a logic 1. When U = 0, SSO is set to a logic 0. The SSO 
is compared with the side information In the Sector I.D. Field. 
If they do not compare Status Bit 4 (RNF) is set. The Side 
Select Output is only updated at the beginning of a Type II or 
III command. It is forced to a logic upon a MASTER RESET 
condition. 


26 
27 


READ CLOCK 


RCLK 


A nominal square-wave clock signal derived from the data 
stream must be provided to this input. Phasing (i.e. RCLK 
transitions) relative to RAW READ is Important but polarity 
(RCLK high or low) is not. 

The data input signal directly from the drive. This input shall 
be a negative pulse for each recorded flux transition. 


RAW READ 


RAW READ 


28 


HEAD LOAD 


HLD 


The HLD output controls the loading of the Read-Write head 
against the media 


29 


TRACK GREATER THAN 43 


TG43 


This output informs the drive that the Read/Write head is 
positioned between tracks 44-76. This output is valid only 
during Read and Write Commands. 


30 


WRITE GATE 


WG 


This output is made valid before writing is to be performed on 
the diskette. 


31 


WRITE DATA 


WD 


A 200 ns (MFM) or 500 ns (FM) output pulse per flux transition. 
WD contains the unique Address marks as well as data and 
clock in both FM and MFM formats. 


32 
33 

34 


READY 


READY 


This input indicates disk readiness and is sampled for a logic 
high before Read or Write commands are performed. If Ready 
is low the Read or Write operation is not performed and an 
interrupt is generated. Type I operations are performed 
regardless of the state of Ready. The Ready input appears in 
inverted format as Status Register bit 7. 

This is a bi-directional signal used to signify writing faults at 
the drive, and to enable the external PLO data separator. When 
WG = 1, Pin 33 functions as a WF input. If WF = 0, any write 
command will immediately be terminated. When WG = 0, Pin 
33 functions as a VFOE output. VFOE will go low during a read 
operation after the head has loaded and settled (HLT = 1). On 
the 1795/7, it will remain low until the last bit of the second 
CRC byte in the ID field. VFOE will then go high until 8 bytes 
(MFM) or 4 bytes (FM) before the Address Mark. It will then go 
active until the last bit of the second CRC byte of the Data 
Field. On the 1791/3, VFOE will remain low until the end of the 
Data Field. This pin has an internal 100K Ohm pull-up resistor. 

This input informs the FD179X that the Read/Write head is 
positioned over Track 00. 


WRITE FAULT 
VFO ENABLE 


WF/VFOE 
TROO 


TRACK 00 



Tl 
D 

CO 

g 

to 
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Western Digital Data Sheet 
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PIN NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


35 
36 

37 




IP 


This input informs the FD179X when the index hole is en- 
countered on the diskette. 

This input is sampled whenever a Write Command is received. 
A logic low terminates the command and sets the Write 
Protect Status bit. 

This input pin selects either single or double density 
operation. When DDEN = 0, double density is selected. When 
DDEN = 1, single density is selected. This line must be left 
open on the 1792/4. 


INDEX PULSE 


WRITE PROTECT 


WPRT 


DOUBLE DENSITY 


DDEN 



GENERAL DESCRIPTION 

The FD179X are N-Channel Silicon Gate MOS LSI 
devices which perform the functions of a Floppy Disk 
Formatter/Controller in a single chip implementation. 
The FD179X, which can be considered the end result 
of both the FD1771 and FD1781 designs, is IBM 3740 
compatible in single density mode (FM) and System 34 
compatible in Double Density Mode (MFM). The 
FD179X contains all the features of its predecessor the 
FD1771, plus the added features necessary to 
read/write and format a double density diskette. These 
include address mark detection, FM and MFM encode 
and decode logic, window extension, and write precom- 
pensation. In order to maintain compatibility, the 
FD1771, FD1781, and FD179X designs were made as 
close as possible with the computer interface, instruc- 
tion set, and I/O registers being identical. Also, head 
load control is identical. In each case, the actual pin 
assignments vary by only a few pins from any one to 
another. 

The processor interface consists of an 8-bit bi-direc- 
tional bus for data status, and control word transfers. 
The FD179X is set up to operate on a multiplexed bus 
with other bus-oriented devices. 

The FD179X is TTL compatible on all inputs and 
outputs. The outputs will drive ONE TTL load or three 
LS loads. The 1793 is identical to the 1791 except the 
DAL lines are TRUE for systems that utilize true data 
busses. 

The 1795/7 has a side select output for controlling 
double sided drives, and the 1792 and 1794 are "Single 
Density Only" versions of the 1791 and 1793 respec- 
tively. On these devices, DDEN must be left open. 

ORGANIZATION 

The Floppy Disk Formatter block diagram is illustrated 
on page 5. The primary sections include the parallel 
processor interface and the Floppy Disk interface. 

Data Shift Register — This 8-bit registe r assembles 
serial data from the Read Data input (RAW READ) 
during Read operations and transfers serial data to the 
Write Data output during Write operations. 
Data Register — This 8-bit register is used as a 
holding register during Disk Read and Write operations. 
In Disk Read operations the assembled data byte is 
transferred in parallel to the Data Register from the 
Data Shift Register. In Disk Write operations in- 
formation is transferred in parallel from the Data 
Register to the Data Shift Register. 



When executing the Seek command the Data Register 
holds the address of the desired Track position. This 
register is loaded from the DAL and gated onto the 
DAL under processor control. 

Track Register — This 8-bit register holds the track 
number of the current Read/Write head position. It is 
incremented by one every time the head is stepped in 
(towards track 76) and decremented by one when the 
head is stepped out (towards track 00). The contents of 
the register are compared with the recorded track 
number in the ID field during disk Read, Write, and 
Verify operations. The Track Register can be loaded 
from or transferred to the DAL. This Register should 
not bejoaded when the device is busy. 
Sector Register (SR) — This 8-bit register holds the address 
of the desired sector position. The contents of the register 
are compared with the recorded sector number in the ID 
field during disk Read or Write operations. The Sector 
Register contents can be loaded from or transferred to the 
DAL. This register should not be loaded when the device is 
busy. 

Command Register (CR) — This 8-bit register holds the 
command presently being executed. This register should 
not be loaded when the device is busy unless the new 
command is a force interrupt. The command register can 
be loaded from the DAL, but not read onto the DAL 
Status Register (STR) — This 8-bit register holds device 
Status information. The meaning of the Status bits is a 
function of the type of command previously executed. This 
register can be read onto the DAL, but not loaded from the 
DAL 

CRC Logic — This logic is used to check or to generate the 
16-bit Cyclic Redundancy Check (CRC). The polynomial is: 
G(x) = x ,s + x' 2 + x 5 + 1. 

The CRC includes all information starting with the address 
mark and up to the CRC characters. The CRC register is 
preset to ones prior to data being shifted through the 
circuit. 

Arithmetic/Logic Unit (ALU) — The ALU is a serial com- 
parator, incrementer, and decrementer and is used for 
register modification and comparisons with the disk 
recorded ID field. 

Timing and Control — All computer and Floppy Disk In- 
terface controls are generated through this logic. The in- 
ternal device timing is generated from an external crystal 
clock. 

The FD179X has two differen t mode s of operation ac- 
cording to the state of DDEN. When DDEN = double 
density (MFM) is assumed. When DDEN = 1, single 
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FD179X BLOCK DIAGRAM 



density (FM) is assumed. 1792 & 1794 are single density 
only. 

AM Detector — The address mark detector detects ID, data 
and index address marks during read and write operations. 

PROCESSOR INTERFACE 

The interface to the process or is accomplished through the 
eight Data Access Lines (DAL) and associated control 
signals. The DAL are used to transfer Dat a Sta tus, and 
Control words out of, or into the FD179X. The DAL are three 
state buffers that are enabled as output drivers when Chip 
Select (CS) and Read Enable (RE)_a_re active (low logic state) 
or act as input receivers when CS and Write Enable (WE) 
are active. 

When transfer of data with the Floppy Disk Controller is 
required by the host processor, the device address is 
decoded and CS is made low/The address bits A1 and AO, 
combined with the signals RE during a Read operation or 
WE during a Write operation are interpreted as selecting 
the following registers: 



A1 - AO 



READ (RE) 



WRITE (WE) 



Status Register 

1 Track Register 

1 Sector Register 
1 1 Data Register 



Command Register 
Track Register 
Sector Register 
Data Register 



During Direct Memory Access (DMA) types of data 
transfers between the Data Register of the FD179X and the 
processor, the Data Request (DRQ) output is used in Data 
Transfer control. This signal also appears as status bit 1 
during Read and Write operations. 

On Disk Read operations the Data Request is activated (set 
high) when an assembled serial input byte is transferred in 
parallel to the Data Register. This bit is cleared when the 
Data Register is read by the processor. If the Data Register 
is read after one or more characters are lost, by having new 
data transferred into the register prior to processor readout, 
the Lost Data bit is set in the Status Register. The Read 
operation continues until the end of sector is reached. 

On Disk Write operations the data Request is activated 
when the Data Register transfers its contents to the Data 
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Shift Register, and requires a new data byte. It is reset 

when the Data Register is loaded with new data by the 

processor. If new data is not loaded at the time the next 

serial byte is required by the Floppy Disk, a byte of zeroes 

is written on the diskette and the Lost Data bit is set in the 

Status Register. 

At the completion of every command an INTRQ is 

generated. INTRQ is reset by either reading the status 

register or by loading the command register with a new 

command. In addition, INTRQ is generated if a Force 

Interrupt command condition is met. 

The 179 X has two modes of opera tion according to the 

state of DDEN (Pin 37). When DDEN = 1, single density is 

selected. In either case, the CLK input (Pin 24) is at 2 MHz. 

However, when interfacing with the mini-floppy, the CLK 

input is set at 1 MHz for both single density and double 

density. 

GENERAL DISK READ OPERATIONS 

Sector lengths of 128, 256, 512 or 1024 are o btainable in 

either FM or MFM formats. For FM, DDEN should be 

placed to logical "1." For MFM formats, DDEN should be 

placed to a logical "0." Sector lengths are determined at 

format time by the fourth byte in the "ID" field. 



Sector Length Table* 



Sector Length 
Field (hex) 



Number of Bytes 
in Sector (decimal) 



00 
01 
02 
03 



128 

256 

512 

1024 



* 1795/97 may vary — see command summary. 
The number of sectors per track as far as the FD179X is 
concerned can be from 1 to 255 sectors. The number of 
tracks as far as the FD179X is concerned is from to 255 
tracks. For IBM 3740 compatibility, sector lengths are 128 
bytes with 26 sectors per track. For System 34 com- 
patibility (MFM), sector lengths are 256 bytes/sector with 26 
sectors/track; or lengths of 1024 bytes/sector with 8 
sectors/track. (See Sector Length Table) 
For rea d operations in 8" double density the FD179X 
requires RAW READ Data (Pin 27) signal which is a 200 ns 
pulse per flux transition and a Read clock (RCLK) signal to 
indicate flux transition spacings. The RCLK (Pin 26) signal 
is provided by some drives but if not it may be derived 
externally by Phase lock loops, one shots, or counter 
techniques. In addition, a Read Gate Signal is provided as 
an output (Pin 25) on 1791/92/93/94 which can be used to 
inform phase lock loops when to acquire synchronization. 
When reading from the media in FM. RG is made true when 
2 bytes of zeroes are detected. The FD179X must find an 
address mark within the next 10 bytes; otherwise RG is 
reset and the search for 2 bytes of zeroes begins all over 
again. If an address mark is found within 10 bytes, RG 
remains true as long as the FD179X is deriving any useful 
information from the data stream. Similarly for MFM, RG is 
made active when 4 bytes of "00" or "FF" are detected. The 
FD179X must find an address mark within the next 16 
bytes, otherwise RG is reset and search r esume s. 
During read operations (WG = 0), the VF OE (Pin 33) is 
provided for phase lock loop synchronization. VFOE will go 
active low when: 



Both HLT and HLD are True 

Settling Time, if programmed, has expired 

The 179X is inspecting data off the disk 



If WF/ VFOE is not used, leave open or tie to a 10K resistor 

to +5. 

GENERAL DISK WRITE OPERATION 

When writing is to take place on the diskette the Write Gate 
(WG) output is activated, allowing current to flow into the 
Read/Write head. As a precaution to erroneous writing the 
first data byte must be loaded into the Data Register in 
response to a Data Request from the FD179X before the 
Write Gate signal can be activated. 
Writing is inhibited when the Write Protect input is a logic 
low, in which case any Write command is immediately 
terminated, an interrupt is generated and the Write Protect 
status bit is set. The Write Fault input, when activated, 
signifies a writing fault condition detected in disk drive 
electronics such as failure to detect write current flow 
when the Write Gate is activated. On detection of this fault 
the FD179X terminates the current command, and sets the 
Write Fault bit (bit 5) in the Status Word. The Write Fault 
input should be made inactive when the Write Gate output 
becomes inactive. 

For write operations, the FD179X provides Write Gate (Pin 
30) and Write Data (Pin 31) output s. Write data consists of a 
series of 500 n s puls es in FM (DDEN = 1) and 200 ns 
pulses in MFM (DDEN = 0). Write Data provides the unique 
address marks in both formats. 

Also during write, two additional signals are provided for 
write precompensation. These are EARLY (Pin 17) and 
LATE (Pin 18). EARLY is active true when the WD pulse 
appearing on (Pin 30) is to be written EARLY. LATE is active 
true when the WD pulse is to be written LATE. If both 
EARLY and LATE are low when the WD pulse is present, 
the WD pulse is to be written at nominal. Since write 
precompensation values vary from disk manufacturer to 
disk manufacturer, the actual value is determined by 
several one shots or delay lines which are located external 
to the FD179X. The write precompensation signals EARLY 
and LATE are valid for the duration of WD in both FM and 
MFM formats. 

READY 

Whenever a Read or Write command (Type II or III) is 
received the FD179X samples the Ready input. If this input 
is logic low the command is not executed and an interrupt 
is generated. All Type I commands are performed re- 
gardless of the state of the Ready input. Also, whenever a 
Type II or III command is received, the TG43 signal output 
is updated. 

COMMAND DESCRIPTION 

The FD179X will accept eleven commands. Command 
words should only be loaded in the Command Register 
when the Busy status bit is off (Status bit 0). The one 
exception is the Force Interrupt command. Whenever a 
command is being executed, the Busy status bit is set. 
When a command is completed, an interrupt is generated 
and the Busy status bit is reset. The Status Register 
indicates whether the completed command encountered 
an error or was fault free. For ease of discussion, 
commands are divided into four types. Commands and 
types are summarized in Table 1. 
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TABLE 1. COMMAND SUMMARY 



A. Commands for Models: 1791, 1792, 1793, 1794 










B. Commands for Models: 1795, 1797 




Bits 












Bits 








Type Command 7 6 5 4 


3 


2 


1 





7 


6 


5 4 3 


2 


1 





I Restore 


h 


V 


M 


ro 








h 


V 


ri 


ro 


I Seek 1 


h 


V 


M 


ro 








1 h 


V 


ri 


ro 


I Step 1 T 


h 


V 


'1 


ro 








1 T h 


V 


ri 


ro 


I Step-in 1 T 


h 


V 


M 


ro 





1 


T h 


V 


M 


ro 


I Step-out 1 1 T 


h 


V 


ri 


ro 





1 


1 T h 


V 


ri 


ro 


II Read Sector 10 0m 


S 


E 


C 





1 





m L 


E 


U 





II Write Sector 10 1m 


S 


E 


C 


ao 


1 





1 m L 



E 


U 


ao 


III Read Address 110 





E 








1 


1 


E 


U 





III Read Track 1110 





E 








1 


1 


1 


E 


U 





III Write Track 1111 





E 








1 


1 


1 1 


E 


U 





IV Force Interrupt 110 1 


13 


l2 


h 


io 


1 


1 


1 l3 


'2 


11 


io 



FLAG SUMMARY 



TABLE 2. FLAG SUMMARY 



Command 
Type 


Bit 
No(s) 




Description 




0,1 


r 1 ro = Stepping Motor Rate 
See Table 3 for Rate Summary 








2 


V = Track Number Verify Flag 


V = 0, No verify 

V = 1, Verify on destination track 






3 


h = Head Load Flag 


h = 1 , Load head at beginning 
h = 0, Unload head at beginning 






4 


T = Track Update Flag 


T = 0, No update 

T = 1, Update track register 


• 


II 





30 = Data Address Mark 


a0=0,FB(DAM) 

30= 1,F8 (deleted DAM) 




II 


1 


C = Side Compare Flag 


C = 0, Disable side compare 
C = 1, Enable side compare 




II & III 


1 


U = Update SSO 


U =0, Update SSO too 
U = 1, Update SSO to 1 




II & III 


2 


E = 15 MS Delay 


E =0, No 15 MS delay 
E = 1,15 MS delay 




II 
II 

II 


3 
3 

4 


S = Side Compare Flag 
L = Sector Length Flag 


S = 0, Compare for side 
S = 1, Compare for side 1 




LSB's Sector Length in ID Field 
00 01 10 11 


L =0 256 512 1024 128 


L = 1 128 256 512 1024 


m = Multiple Record Flag 


m = 0, Single record 
m = 1, Multiple records 




IV 


0-3 


•x = Interrupt Condition Flags 

'O =1 Not Ready To Ready Transition 

h = 1 Ready To Not Ready Transition 

'2 =1 Index Pulse 

'3 = 1 1mmediate Interrupt, Requires A Reset 

l3-k) = Terminate With No Interrupt (I NTRQ) 





-J 

CO 

© 
10 



"NOTE: See Type IV Command Description for further information. 
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TYPE I COMMANDS 

The Type I Commands include the Restore, Seek, Step, 
Step-In, and Step-Out commands. Each of the Type I 
Commands contains a rate field CO r 1), which determines 
the stepping motor rate as defined in Table 3. 
A 2 ms (MFM) or 4 us (FM) pulse is provided as an output to 
the drive. For every step pulse issued, the drive moves one 
track location in a direction determined by the direction 
output. The chip will step the drive in the same direction it 
last stepped unless the command changes the direction. 

The Direction signal is active high when stepping in and 
low when stepping out. The Direction signal is valid 12 us 
before the first stepping pulse is generated. 

The rates (shown in Table 3) can be applied to a Step- 
Direction Motor through the device interface. 







TABLE 3. 


STEPPING RATES 




CLK 


2 MHz 


2 MHz 


1 MHz 


1 MHz 


2 MHz 


1 MHz 


DDEN 





1 





1 


X 


X 


R1 RO 


TEST=1 


TEST=1 


TEST=1 


TEST=1 


TEST=0 


TEST=0 





3 ms 


3 ms 


6 ms 


6 ms 


184^s 


368ns 


1 


6 ms 


6 ms 


12 ms 


12 ms 


190ms 


380/xs 


1 


10 ms 


10 ms 


20 ms 


20 ms 


198ms 


396f»s 


1 1 


15 ms 


15 ms 


30 ms 


30 ms 


208^s 


416/xs 



After the last directional step an additional 15 milliseconds 
of head settling time takes place if the Verify flag is set in 
Type I commands. Note that this time doubles to 30 ms for 
a 1 MHz clock. If TEST = 0, there is zero settling time. 
There is also a 15 ms head settling time if the E flag is set in 
any Type II or III command. 

When a Seek, Step or Restore command is executed an 
optional verification of Read-Write head position can be 
performed by settling bit 2 (V = 1) in the command word to 
a logic 1. The verification operation begins at the end of the 
15 millisecond settling time after the head is loaded against 
the media. The track number from the first encountered ID 
Field is compared against the contents of the Track 
Register. If the track numbers compare and the ID Field 
Cyclic Redundancy Check (CRC) is correct, the verify 
operation is complete and an INTRQ is generated with no 
errors. If there is a match but not a valid CRC, the CRC error 
status bit is set (Status bit 3), and the next encountered ID 
field is read from the disk for the verification operation. 

The FD179X must find an ID field with correct track number 
and correct CRC within 5 revolutions of the media; 
otherwise the seek error is set and an INTRQ is generated. 
If V = 0, no verification is performed. 

The Head Load (HLD) output controls the movement of the 
read/write head against the media. HLD is activated at the 
beginning of a Type I command if the h flag is set (h = 1), at 
the end of the Type I command if the verify flag (V = 1), or 
upon receipt of any Type II or III command. Once HLD is 
active it remains active until either a Type I command is 
received with (h = and V = 0); or if the FD179X is in an 
idle state (non-busy) and 15 index pulses have occurred. 



Head Load timing (HLT) is an input to the FD179X which is 
used for the head engage time. When HLT = 1, the FD179X 
assumes the head is completely engaged. The head 
engage time is typically 30 to 100 ms depending on drive. 
The low to high transition on HLD is typically used to fire a 
one shot. The output of the one shot is then used for HLT 
and supplied as an input to the FD179X. 



HLDf- 






-50 TO 100mS- 



HLT (FROM ONE SHOT) 



HEAD LOAD TIMING 

When both HLD and HLT are true, the FD179X will then 
read from or write to the media. The "and" of HLD and HLT 
appears as status Bit 5 in Type I status. 

In summary for the Type I commands: if h = and V = 0, 
HLD is reset. If h = 1 and V = 0, HLD is set at the 
beginning of the command and HLT is not sampled nor is 
there an internal 15 ms delay. If h = and V = 1, HLD is 
set near the end of the command, an internal 15 ms occurs, 
and the FD179X waits for HLT to be true. If h = 1 and V = 
1, HLD is set at the beginning of the command. Near the 
end of the command, after all the steps have been issued, 
an internal 15 ms delay occursand the FD179X then waits 
for HLT to occur. 

For Type II and III commands with E flag off, HLD is made 
active and HLT is sampled until true. With E flag on, HLD is 
made active, an internal 15 ms delay occurs and then HLT 
is sampled until true. 

RESTORE (SEEK TRACK 0) 

Upon receip t of th is command the Track 00 (TR00) input is 
sampled. If TROO is active low indicating the Read-Write 
head is positioned over track 0, the Track Regi ster is loaded 
with zeroes and an interrupt is generated. If TROO is not 
active low, stepping pulses (pins 15 to 16) at a rate specified 
by the 1 r field are issued until the TROO input is activated. 
At this time the Track Regist er is lo aded with zeroes and an 
interrupt is generated. If the TROO input does not go active 
low after 255 stepping pulses, the FD179X terminates 
operation, interrupts, and sets the Seek error status bit, 
providing the V flag is set. A verification operation also 
takes place if the V flag is set. The h bit allows the head to 
be loaded at the start of command. Note that the Restore 
command is executed when MR goes from an active to an 
inactive state and that the DRQ pin stays low. 

SEEK 

This command assumes that the Track Register contains 
the track number of the current position of the Read-Write 
head and the Data Register contains the desired track 
number. The FD179X will update the Track register and 
Issue stepping pulses in the appropriate direction until the 
contents of the Track register are equal to the contents of 
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TYPE I COMMAND FLOW 

the Data Register (the desired track location). A verification 
operation takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An interrupt 
is generated at the completion of the command. Note: 
When using multiple drives, the track register must be 
updated for the drive selected before seeks are issued. 

STEP 

Upon receipt of this command, the FD179X issues one 
stepping pulse to the disk drive. The stepping motor 
direction is the same as in the previous step command. 
After a delay determined by the r 1f0 field, a verification 
takes place if the V flag is on. If the U flag is on, the Track 
Register is updated. The h bit allows the head to be loaded 
at the start of the command. An interrupt is generated at 
the completion of the command. 

STEP-IN 

Upon receipt of this command, the FD179X issues one 
stepping pulse in the direction towards track 76. If the U 



TYPE I COMMAND FLOW 

flag is on, the Track Register is incremented by one. After a 
delay determined by the r 1 r field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 

STEP-OUT 

Upon receipt of this command, the FD179X issues one 
stepping pulse in the direction towards track 0. If the U flag 
is on, the Track Register is decremented by one. After a 
delay determined by the r 1 r field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 

EXCEPTIONS 

On the 1795/7 devices, the SSO output is not affected 
during Type 1 commands, and an internal side compare 
does not take place when the (V) Verify Flag is on. 
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VERIFY 
SEQUENCE 



INTRO RESET BUSY 








jsA 



(INTRO J 

RESET BUSY J ' 



then located and will be either written into, or read from 
depending upon the command. The FD179X must find an 
ID field with a Track number, Sector number, side number, 
and CRC within four revolutions of the disk; otherwise, the 
Record not found status bit is set (Status bit 3) and the 
command is terminated with an interrupt. 



TYPE I COMMAND FLOW 

TYPE II COMMANDS 

The Type II Commands are the Read Sector and Write 
Sector commands. Prior to loading the Type II Command 
into the Command Register, the computer must load the 
Sector Register with the desired sector number. Upon 
receipt of the Type II command, the busy status Bit is set. If 
the E flag = 1 (this is the normal case) HLD is made active 
and HLT is sampled after a 15 msec delay. If the E flag is 0, 
the head is loaded and HLT sampled with no 15 msec 
delay. The ID field and Data Field format are shown on page 
13. 

When an ID field is located on the disk, the FD179X 
compares the Track Number on the ID field with the Track 
Register. If there is not a match, the next encountered ID 
field is read and a comparison is again made. If there was a 
match, the Sector Number of the ID field is compared with 
the Sector Register. If there is not a Sector match, the next 
encountered ID field is read off the disk and comparisons 
again made. If the ID field CRC is correct, the data field is 




J < TR>43 > 


YES 


SET 
TG43 




JNO 








RESET TOM 






- \m 






1 MHz. THERE IS 30MS DELAY 



TYPE II COMMAND 

Each of the Type II Commands contains an (m) flag which 
determines if multiple records (sectors) are to be read or 
written, depending upon the command. If m = 0, a single 
sector is read or written and an interrupt is generated at the 
completion of the command. If m = 1, multiple records are 
read or written with the sector register internally updated 
so that an address verification can occur on the next 
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record. The FD179X will continue to read or write multiple 
records and update the sector register in numerical 
ascending sequence until the sector register exceeds the 
number of sectors on the track or until the Force Interrupt 
command is loaded into the Command Register, which 
terminates the command and generates an interrupt. 

For example: If the FD179X is instructed to read sector 27 
and there are only 26 on the track, the sector register ex- 
ceeds the number available. The FD179X will search for 5 
disk revolutions, interrupt out, reset busy, and set the 
record not found status bit. 

The Type II commands for 1791-94 also contain side select 
compare flags. When C = (Bit 1) no side comparison is 
made. When C = 1, the LSB of the side number is read off 
the ID Field of the disk and compared with the contents of 
the (S) flag (Bit 3). If the S flag compares with the side 
number recorded In the ID field, the FD179X continues with 
the ID search. If a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 




IHOf 



BRING IN SECTOR LENGTH FIELD 

STORE LENGTH IN INTERNAL 

REGISTER 








The Type II and III commands for the 1795-97 contain a side 
select flag (Bit 1). When U = 0, SSO is updated to 0. 
Similarly, U = 1 updates SSO to 1. The chip compares the 
SSO to the ID field. If they do not compare within 5 
revolutions the interrupt line is made active and the RNF 
status bit is set. 

The 1795/7 READ SECTOR and WRITE SECTOR com- 
mands include a 'L' flag. The 'L' flag, in conjunction with 
the sector length byte of the ID Field, allows different byte 
lengths to be implemented in each sector. For IBM 
compatability, the 'L' flag should be set to a one. 

READ SECTOR 

Upon receipt of the Read Sector command, the head is 
loaded, the Busy status bit set, and when an ID field is 
encountered that has the correct track number, correct 
sector number, correct side number, and correct CRC, the 
data field is presented to the computer. The Data Address 



"TI 

o 
^J 

CO 

X 

i 

o 
ro 



READ SECTOR 
SEQUENCE 



c 




INTRO RESET BUST 







TYPE II COMMAND 



timmKmtnam.im'ji.mjj.uumwhismwL.'umyni 



TYPE li COMMAND 

iBIWIfaHWiWi'WIIIIIHIIIHIHIlg 



27 



Western Digital Data Sheet 



"n 

a 

? 

O 

10 



s 



WRITE SECTOR 
SEQUENCE 



DELAY 2 BYTES OF GAP 




J INTHO. BESET BUSY J 
^ SET LOST OATA i 



OELAY 1 BYTE OF GAP 




DELAY 11 BYTES 



WRITE DATA AM 
ACCORDING TO AO FIELD 
OF WRITE COMMAND 



DR TO DSR. SET DRQ 



WRITE BYTE TO DISK 




SET DATA 

LOST 

WRITE BYTE 

OF ZEROS 



Q 



WRITE 1 BYTE OF FF 



TURN OFF WG 



TYPE II COMMAND 

Mark of the data field must be found within 30 bytes in 
single density and 43 bytes in double density of the last ID 
field CRC byte; if not, the ID field is searched for and 
verified again followed by the Data Address Mark search. If 
after 5 revolutions the DAM cannot be found, the Record 
Not Found status bit is set and the operation is terminated. 
When the first character or byte of the data field has been 
shifted through the DSR, it is transferred to the DR, and 
DRQ is generated. When the next byte is accumulated in 
the DSR, it is transferred to the DR and another DRQ is 
generated. If the Computer has not' read the previous 
contents of the DR before a new character is transferred 
that character is lost and the Lost Data Status bit is set. 
This sequence continues until the complete data field has 
been inputted to the computer. If there is a CRC error at the 
end of the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple record 
command). 

At the end of the Read operation, the type of Data Address 
Mark encountered in the data field is recorded in the Status 
Register (Bit 5) as shown: 



STATUS 
BIT 5 



1 Deleted Data Mark 

Data Mark 

WRITE SECTOR 

Upon receipt of the Write Sector command, the head is 
loaded (HLD active) and the Busy status bit is set. When an 
ID field is encountered that has the correct track number, 
correct sector number, correct side number, and correct 
CRC, a DRQ is generated. The FD179X counts off 11 bytes 
in single density and 22 bytes in double density from the 
CRC field and the Write Gate (WG) output is made active if 
the DRQ is serviced (i.e., the DR has been loaded by the 
computer). If DRQ has not been serviced, the command is 
terminated and the Lost Data status bit is set. If the DRQ 
has been serviced, the WG is made active and six bytes of 
zeroes in single density and 12 bytes in double density are 
then written on the disk. At this time the Data Address 
Mark is then written on the disk as determined by the a 
field of the command as shown below: 



ao 



Data Address Mark (Bit 0) 



1 Deleted Data Mark 

Data Mark 

The FD179X then writes the data field and generates DRQ's 
to the computer. If the DRQ is not serviced in time for 
continuous writing the Lost Data Status Bit is set and a 
byte of zeroes is written on the disk. The command is not 
terminated. After the last data byte has been written on the 
disk, the two-byte CRC is computed internally and written 
on the disk followed by one byte of logic ones in FM or in 
MFM. The WG output is then deactivated. For a 2 MHz 
clock the INTRQ will set 8 to 12nsec after the last CRC byte 
is written. For partial sector writing, the proper method is to 
write the data and fill the balance with zeroes. By letting the 
chip fill the zeroes, errors may be masked by the lost data 
status and improper CRC Bytes. 

TYPE III COMMANDS 

READ ADDRESS 

Upon receipt of the Read Address command, the head 
is loaded and the Busy Status Bit is set. The next 
encountered ID field is then read in from the disk, and 
the six data bytes of the ID field are assembled and 
transferred to the DR, and a DRQ is generated for each 
byte. The six bytes of the ID field are shown below: 



TRACK 
ADDR 


SIDE 
NUMBER 


SECTOR 
ADDRESS 


SECTOR 
LENGTH 


CRC 
1 


CRC 
2 


1 


2 


3 


4 


5 


6 



Although the CRC characters are transferred to the 
computer, the FD179X checks for validity and the CRC 
error status bit is set if there is a CRC error. The Track 
Address of the ID field is written into the sector 
register so that a comparison can be made by the 
user. At the end of the operation an interrupt is 
generated and the Busy Status is reset. 
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READ TRACK 

Upon receipt of the READ track command, the head is 
loaded, and the Busy Status bit is set. Reading starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse. All Gap, Header, and 
data bytes are assembled and transferred to the data 
register and DRQ's are generated for each byte. The ac- 
cumulation of bytes is synchronized to each address mark 
encountered. An interrupt is generated at the completion of 
the command. 

This command has several characteristics which make it 
suitable for diagnostic purposes. They are: the Read Gate 



is not activated during the command; no CRC checking is 
performed; gap Information is included in the data stream; 
the internal side compare is not performed; and the ad- 
dress mark detector is on for the duration of the command. 
Because the A.M. detector is always on, write splices or 
noise may cause the chip to look for an A.M. If an address 
mark does not appear on schedule the Lost Data status flag 
is set. 

The ID A.M., ID field, ID CRC bytes, DAM, Data, and Data 
CRC Bytes for each sector will be correct. The Gap Bytes 
may be read incorrectly during write-splice time because of 
synchronization. 



to 

o 
to 




X INTB0 1 

^ RESET BUSY J 





NO 


———•J 

yr HAS 
y^ 11 MS 












NO 


-jr * 



T04I update 








SET INTRO 
LOST DATA 
RESET BUSY 







YES (MFMI 


t B 1 

£ Eden ^s 

V. .0 yS 

Tnoifmi 


YES^ 
YES_ 
YES 














yr DOES >v. 

< DSR « F7 > 

^V^ 1 , yT 

jno 

yr DOES ^S. 

< DSR ■ FC s> 
>v 1 yr 

JNO 

yS does >s. 
/ DSR ■ FD, FE, ^S. 
\^ OR Fa-Ft) yr 


WRITE 2 CRC 
CHARS. CLK • FF 












WRITE FC 
CLK • D7 






WRITE FD. FE OR 
F»FB, CLK - C7 
INITIALIZE CRC 






JNO 






WRITE DSR 
CLK • FF 












NO 

YES _ 

YES 

YES 






I INTRO RESET BUSY J 


YES^"^ PHYS ^V. 

•— C^ INDEX MARK J> 

1 NO 




YES 


y^ HAS ^S. 
< DR BEEN j* 
^•v LOADED? y 


WRITE 
BYTE OF ZEROS 
SET OATA LOST 


r-L,' 











N/ 


S °° a ^S- 


WRITE AT INMFM 
WITH MISSING CLOCK 
INITIALIZE CRC 






v^ osr ■ fj y^ 




• Jno 

jS ooes ^V 

< DSH > n >- 

JNO • 
yT DOES ^s. 

< osr . n j> 

>s. ' y 




WRITE C2' IN MFM 
WITH MISSING CLOCK 






WRITE 2 CRC 
CHARS 






JNO 






WRITE OSR 
INMFM 

















TYPE III COMMAND WRITE TRACK 



TYPE III COMMAND WRITE TRACK 
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CONTROL BYTES FOR INITIALIZATION 



DATA PATTERN 
IN DR (HEX) 


FD179X INTERPRETATION 


FD1 791/3 INTERPRETATION 
IN MFM (DT5ER = 0) 


IN FM (DDEN = 1) 


00 thru F4 


Write 00 thru F4 with CLK = FF 


Write 00 thru F4, in MFM 


F5 


Not Allowed 


Write A1* in MFM, Preset CRC 


F6 


Not Allowed 


Write C2** in MFM 


F7 


Generate 2 CRC bytes 


Generate 2 CRC bytes 


F8 thru FB 


Write F8 thru FB, Clk = C7, Preset CRC 


Write F8 thru FB, in MFM 


FC 


Write FC with Clk = D7 


Write FC in MFM 


FD 


Write FD with Clk = FF 


Write FD in MFM 


FE 


Write FE, Clk = C7, Preset CRC 


Write FE in MFM 


FF 


Write FF with Clk = FF 


Write FF in MFM 



* Missing clock transition between bits 4 and 5 



"Missing clock transition between bits 3 & 4 



WRITE TRACK FORMATTING THE DISK 

(Refer to section on Type III commands for flow diagrams.) 

Formatting the disk is a relatively simple task when 
operating programmed I/O or when operating under DMA 
with a large amount of memory. Data and gap information 
must be provided at the computer interface. Formatting the 
disk is accomplished by positioning the R/W head over the 
desired track number and issuing the Write Track com- 
mand. 

Upon receipt of the Write Track command, the head is 
loaded and the Busy Status bit is set. Writing starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse, at which time the 
interrupt is activated. The Data Request is activated im- 
mediately upon receiving the command, but writing will not 
start until after the first byte has been loaded into the Data 
Register. If the DR has not been loaded by the time the 
index pulse is encountered the operation is terminated 
making the device Not Busy, the Lost Data Status Bit is set, 
and the Interrupt is activated. If a byte is not present in the 
DR when needed, a byte of zeroes is substituted. 

This sequence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears in the 
data register is -written on the disk with a normal clock 
pattern. However, if the FD179X detects a data pattern of 
F5 thru FE in the data register, this is interpreted as data 
address marks with missing clocks or CRC generation. 

The CRC generator is initialized when any data byte from 
F8 to FE is about to be transferred from the DR to the DSR 
in FM or by receipt of F5 in MFM. An F7 pattern will 
generate two CRC characters in FM or MFM. As a con- 
sequence, the patterns F5 thru FE must not appear in the 
gaps, data fields, or ID fields. Also, CRC's must be 
generated by an F7 pattern. 

Disks may be formatted in IBM 3740 or System 34 formats 
with sector lengths of 128, 256, 512, or 1024 bytes. 



TYPE IV COMMANDS 

The Forced Interrupt command is generally used to ter- 
minate a multiple sector read or write command or to in- 



sure Type I status in the status register. This command can 
be loaded into the command register at any time. If there is 
a current command under execution (busy status bit set) 
the command will be terminated and the busy status bit 
reset. 

The lower four bits of the command determine the con- 
ditional interrupt as follows: 

IfJ = Not-Ready to Ready Transition 
'1 = Ready to Not-Ready Transition 
'2 = Every Index Pulse 
'3 = Immediate Interrupt 

The conditional interrupt is enabled when the cor- 
responding bit positions of the command ('3 - '0) are set to 
a 1. Then, when the condition for interrupt is met, the IN- 
TRO line will go high signifying that the condition specified 
has occurred. If '3 - '0 are all set to zero (HEX DO), no in- 
terrupt will occur but any command presently under 
execution will be immediately terminated. When using the 
immediate interrupt condition ('3 = 1) an interrupt will be 
immediately generated and the current command ter- 
minated. Reading the status or writing to the command 
register will not automatically clear the interrupt. The HEX 
DO is the only command that will enable the immediate 
interrupt (HEX D8) to clear on a subsequent load command 
register or read status register operation. Follow a HEX D8 
with DO command. 

Wait 8 micro sec (double density) or 16 micro sec (single 
density before issuing a new command after issuing a 
forced interrupt (times double when clock = 1 MHz). 
Loading a new command sooner than this will nullify the 
forced interrupt. 

Forced interrupt stops any command at the end of an in- 
ternal micro-instruction and generates INTRO when the 
specified condition is met. Forced interrupt will wait until 
ALU operations in progress are complete (CRC 
calculations, compares, etc.). 

More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (h = 1) 
and the Every Index Pulse ('2 = 1) are both set, the 
resultant command would be HEX "DA". The "OR" func- 
tion is performed so that either a READY TO NOT- READY 
or the next Index Pulse will cause an interrupt condition. 
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SET BUSY 

RESET STATUS 

BITS 2. 4, 5 





INTRO 
RESET BUSY 



) 



NO 


^ E-1 ^"Si 

[YES 




DELAY 1SMS* 










*r HLT-1 ^V^ 


NO 



READ 
ADDRESS 



I 



READ TRACK 
SEQUENCE 




INDEX 
PULSE 



SHIFT ONE BIT 
INTO DSR 



ISDR 
EMPTY 



TRANSFER 
DSR TO DR 



SET 
DRQ 



•II TEST- ♦. NO DELAY 
II TEST-1 and CLK-1 MHZ. 30 MS DELAY 



TYPE III COMMAND 

Read Track/Address 




<SET INTRO ^ 

RESET BUSY J 




SET LOST 
DATA BIT 



o 

-J 
CO 

X 

© 

IO 
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READ ADDRESS 
SEQUENCE 



RESET BUSY 
SETINTRQ 
SETRNF 



J 







YES 


NO 
UP- 




SHIFT 1 BYTE 
INTO DSR 


< 


' 


TRANSFER 
BYTE TO DR 






SET DRQ 


^/^ HA 

-C BYTE 


VE6 ^N^ 
3 BEEN >• 



TRANSFER TRACK 

NUMBER TO SECTOR 

REGISTOR 




SETCRC 
ERROR BIT 



c 



SET INTRO 
RESET BUSY 



) 



TYPE III COMMAND 

Read Track/Address 



STATUS REGISTER 

Upon receipt of any command, except the Force Interrupt 
command, the Busy Status bit is set and the rest of the 
status bits are updated or cleared for the new command. If 
the Force Interrupt Command is received when there is a 
current command under execution, the Busy status bit is 
reset, and the rest of the status bits are unchanged. If the 
Force Interrupt command is received when there is not a 
current command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or cleared. 
In this case, Status reflects the Type I commands. 

The user has the option of reading the status register 
through program control or using the DRQ line with DMA or 
interrupt methods. When the Data register is read the DRQ 
bit in the status register and the DRQ line are automatically 
reset. A write to the Data register also causes both DRQ's 
to reset. 

The busy bit in the status may be monitored with a user 
program to determine when a command is complete, in 
lieu of using the INTRQ line. When using the INTRQ, a busy 
status check is not recommended because a read of the 
status register to determine the condition of busy will reset 
the INTRQ line. 



The format of the Status Register is shown below: 



(BITS) 


7 


6 


5 


4 


3 


2 


1 





S7 


S6 


S5 


S4 


S3 


S2 


S1 


SO 



Status varies according to the type of command executed 
as shown in Table 4. 

Because of internal sync cycles, certain time delays must 
be observed when operating under programmed I/O. They 
are: (times double when clock = 1 MHz) 



Operation 


Next Operation 


Delay Req'd. 
FM | MFM 


Write to 
Command Reg. 


Read Busy Bit 
(Status Bit 0) 


12fis ! 6fiS 


Write to 
Command Reg. 


Read Status 
Bits 1-7 


28fiS i 14/iS 


Write Any 
Register 


Read From Diff. 
Register 


] 



IBM 3740 FORMAT — 128 BYTES/SECTOR 

Shown below is the IBM single-density format with 128 
bytes/sector. In order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 



"'"1 '■ i r~r^ 
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IBM 3740 FORMAT - 128 BYTES/SECTOR 

Shown below is the IBM single-density format with 128 
bytes/sector. In order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 



IBM SYSTEM 34 FORMAT- 256 BYTES/SECTOR 

Shown below is the IBM dual-density format with 256 
bytes/sector. In order to format a diskette the user must 
issue the Write Track command and load the data register 
with the following values. For every byte to be written, there 
is one data request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


40 
6 


FF(orOO)' 
00 




1 
26 


FC (Index Mark) 

FF(orOO)' 

00 




6 




1 
1 


FE (ID Address Mark) 
Track Number 




1 
1 
1 
1 

11 
6 


Side Number (00 or 01) 
Sector Number (1 thru 1A) 
00 (Sector Length) 
F7 (2 CRC's written) 
FF(orOO)' 
00 




1 

128 

1 

27 


FB (Data Address Mark) 
Data (IBM uses E5) 
F7 (2 CRC's written) 
FF(orOO)' 
FF(orOO)' 




247" 



*Write bracketed field 26 times 
"Continue writing until FD179X interrupts out. 

Approx. 247 bytes. 
1-Optional '00' on 1795/7 only. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


80 


4E 


12 


00 


3 

1 

* 50 


F6 (Writes C2) 
FC (Index Mark) 
4E 
00 


12 


3 
1 
1 
1 
1 
1 
1 
22 


F5 (Writes A1) 
FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Number(1 thru 1A) 
01 (Sector Length) 
F7 (2 CRCs written) 
4E 


12 


00 


3 

1 

256 


F5 (Writes A1) 

FB (Data Address Mark) 

DATA 


1 
54 


F7 (2 CRCs written) 

4E 

4E 


598** 



TI 
O 

s 

o 



*Write bracketed field 26 times 
* 'Continue writing until FD179X interrupts out. 
Approx. 598 bytes. 




MAI 



33 



Western Digital Data Sheet 



CO 

X 

© 
10 



1. NON-IBM FORMATS 

Variations in the IBM formats are possible to a limited 
extent if the following requirements are met: 

1) Sector size must be 128, 256, 512 or 1024 bytes. 

2) Gap 2 cannot be varied from the IBM format. 

3) 3 bytes of A1 must be used in MFM. 

In addition, the Index Address Mark is not required for 
operation by the FD179X. Gap 1, 3, and 4 lengths can be as 
short as 2 bytes for FD179X operation, however PLL lock up 
time, motor speed variation, write-splice area, etc. will add 
more bytes to each gap to achieve proper operation. It is 
recommended that the IBM format be used for highest 
system reliability. 





FM 


MFM 


Gap I 


16 bytes FF 


32 bytes 4E 


Gap II 


11 bytes FF 


22 bytes 4E 


'■ 


6 bytes 00 


12 bytes 00 
3 bytes A1 


Gap III" 


10 bytes FF 
4 bytes 00 


24 bytes 4E 
8 bytes 00 
3 bytes A1 


Gap IV 


16 bytes FF 


16 bytes 4E 



*Byte counts must be exact. 

"Byte counts are minimum, except exactly 3 bytes of A1 
must be written. 




I SERVICE (WORST CASE! 
■FM 27SuS 
■MFM 13 5uS 



ORQ FALLING EDGE. INDICATES THAT THE DATA REGISTER WAS READ 

INTRO RISING EDGE: OCCURS AT END OF COMMAND 

INTRO FALLING EDGE: INDICATES THAT THE STATUS REGISTER WAS READ. 



READ ENABLE TIMING 



TIMING CHARACTERISTICS 

Ta = 0°C to 70°C, Vdd = + 12V ± .6V, Vss = 0V, Vcc =+5V ± .25V 
READ ENABLE TIMING (See Note 6, Page 21) 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR & CS to RE 


50 






nsec 




THLD 


Hold ADDR & CS from RE 


10 






nsec 




TRE 


RE Pulse Width 


400 






nsec 


Cl = 50 pf 


TDRR 


DRQ Reset from RE 




400 


500 


nsec 




TIRR 


INTRQ Reset from RE 




500 


3000 


nsec 


See Note 5 


TDACC 


Data Access from RE 






350 


nsec 


Cl = 50 pf 


TDOH 


Data Hold From RE 


50 




150 


nsec 


Cl = 50 pf 



WRITE ENABLE TIMING (See Note 6, Page 21) 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR & CS to WE 


50 






,nsec 




THLD 


Hold ADDR & CS from WE 


10 






nsec 




TWE 


WE Pulse Width 


350 






nsec 




TDRR 


DRQ Reset from WE 




400 


500 


nsec 




TIRR 


INTRQ Reset from WE 




500 


3000 


nsec 


See Note 5 


TDS 


Data Setup to WE 


250 






nsec 




TDH 


Data Hold from WE 


70 






nsec 
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r 


__ 


J 
1 
1 
1 










T|RR- »-| 


iN T H(3 ) 


1 










1 








-O 






— 


'hld 


1— 




•^ T WE ■"- 














*T 








/,« 






'SET 












DATA MUST 
BE VALID 












, 


— 


'DsU 








■ I T DM | ^ 


(SERVICE (WORST 
•FM 23 5uS 
•MFM IISuS 


NOTE 1 CS MAY BE PERMANENTLY TIED LOW IF DESIRED 

2 WHEN WRITING DATA INTO SECTOR TRACK OR DATA 
REGISTER USER CANNOT READ THIS REGISTER UNTIL 
AT LEAST 4 ,iSEC IN MFM AFTER THE RISING EDGE OF WE 
P ,. tl WHEN WRITING INTO THE COMMAND REGISTER STATUS 
LAStl IS NOT VALIO UNTIL SOME 28 «SEC IN FM. 14„SEC IN MFM 
LATER THESE TIMES ARE DOUBLED WHEN CLK 1 MHl 
•TIME OOUBLES WHEN CLOCK IMHi 






DRQ RISING EDGE: INDICATES THAT THE DATA REGISTER IS EMPTY 
DRO FALLING EDGE INDICATES THAT THE DATA REGISTER IS LOADED 
INTRO RISING EDGE: INDICATE THE ENO OF A COMMAND 
INTRO FALLING EDGE: INDICATES THAT THE COMMAND REGISTER 
IS WRITTEN TO 



RAW READ — 






1 




[I 


-- H h- 




'-1 


' 


u 






















m Ti — 


~. 




- Tt> m~ 




' I - 




" 








NOMINAL 


DISKETTE 


MODE 




CLK 


T. 


T„ 


T c 


DDEN 


8" 
8" 
5" 
5" 


MFM 
FM 

MFM 
FM 



1 

1 


2 MHz 
2 MHz 
1 MHz 
1 MHz 


1 us 

2 tis 

2 MS 

4 us 


1 flS 

2/iS 
2/is 
4 us 


2 ^s 
4/iS 
4 /is 
8 us 



INPUT DATA TIMING 



WRITE ENABLE TIMING 
INPUT DATA TIMING: 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Tpw 

tbc 

Tc 

Txi 

TX2 


Raw Read Pulse Width 


100 

1500 

1500 

40 

40 


200 

2000 
2000 




nsec 
nsec 
nsec 
nsec 
nsec 


See Note 1 
1800 ns@70°C 
1800 ns@70°C 
See Note 1 
See Note 1 


Raw Read Cycle Time 
RCLK Cycle Time 


RCLK hold to Raw Read 


Raw Read hold to RCLK 



WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) 


(See Note 6, Page 21) 




SYMBOL 


CHARACTERISTICS 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Twp 


Write Data Pulse Width 




500 


650 


nsec 


FM 








200 


350 


nsec 


MFM 


Twg 


Write Gate to Write Data 




2 
1 




fisec 
fi.sec 


FM 
MFM 


Tbc 


Write data cycle Time 




2,3, or 4 




fisec 


± CLK Error 


Ts 


Early (Late) to Write Data 


125 






nsec 


MFM 


Th 


Early (Late) From 
Write Data 


125 






nsec 


MFM 


Twf 


Write Gate off from WD 




2 
1 




/usee 
fxsec 


FM 
MFM 


Twdl 


WD Valid to Clk 


100 
50 






nsec 
nsec 


CLK=1 MHZ 
CLK=2 MHZ 


Twd2 


WD Valid after CLK 


100 
30 






nsec 
nsec 


CLK=1 MHZ 
CLK=2 MHZ 



^1 
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CLK 
(2MHZ) 
DOEN = 



~l 



H 



1_ 



V/////A V////A 

Twdl *J L Twd2 



CLK 
(2MHZ) J 

(DDEN =0) L 



V/////A I tW^l 



H I k- 



WD MUST HAVE RISING EDGE IN FIRST SHADED AREA AND TRAILING 
EDGE IN SECOND SHADED AREA. 



WRITE DATA/CLOCK RELATIONSHIP 



WRITE DATA TIMING 



MISCELLANEOUS TIMING: (Times Double When Clock = 1 MHz) (See Note 6, Page 21) 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TCDi 


Clock Duty (low) 


230 


250 


20000 


nsec 




TCD2 


Clock Duty (high) 


200 


250 


20000 


nsec 




TSTP 
TDIR 
TMR 


Step Pulse Output 
Dir Setup to Step 
Master Reset Pulse Width 


2or4 
50 


12 




/xsec 
/isec 
/usee 


See Note 5 
± CLK ERROR 


TIP 


Index Pulse Width 


10 






/xsec 


See Note 5 


TWF 


Write Fault Pulse Width 


10 






/xsec 
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NOTES: 

1. Pulse width on RAW READ (Pin 27) is normally 
100-300 ns. However, pulse may be any width if 
pulse is entirely within window. If pulse occurs in both 
windows, then pulse width must be less than 300 ns 
for MFM at CLK = 2 MHz and 600 ns for FM at 2 
MHz. Times double for 1 MHz. 

2. A PPL Data Separator is recommended for 8" MFM. 

3. tbc should be 2 fis, nominal in MFM and 4 ^s nominal 
in FM. Times double when CLK = 1 MHz. 

4. RCLK may be high or low during RAW READ (Polarity 
is unimportant). 

5. Times double when clock = 1 MHz. 

6. Output timing readings are at Vol = 0.8v and Voh = 
2.0v. 



MISCELLANEOUS TIMING 

•FROM STEP RATE TABLE 

Table 4. STATUS REGISTER SUMMARY 





ALL TYPE 1 


READ 


READ 


READ 


WRITE 


WRITE 


BIT 


COMMANDS 


ADDRESS 


SECTOR 


TRACK 


SECTOR 


TRACK 


S7 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


S6 


WRITE 
PROTECT 











WRITE 
PROTECT 


WRITE 
PROTECT 


S5 


HEAD LOADED 





RECORD TYPE 





WRITE FAULT 


WRITE FAULT 


S4 


SEEK ERROR 


RNF 


RNF 





RNF 





S3 


CRC ERROR 


CRC ERROR 


CRC ERROR 





CRC ERROR 





S2 


TRACK 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


S1 


INDEX PULSE 


DRQ 


DRQ 


DRQ 


DRQ 


DRQ 


SO 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 
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STATUS FOR TYPE I COMMANDS 



BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. 


S6 PROTECTED 


When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT 
input. 


S5 HEAD LOADED 


When set, it indicates the head is loaded and engaged. This bit is a logical "and" of 
HLD and HLT signals. 


S4 SEEK ERROR 


When set, the desired track was not verified. This bit is reset to when updated. 


S3 CRC ERROR 


CRC encountered in ID field. 


S2 TRACK 00 


When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted 
copy of the TROO input. 


S1 INDEX 


When set, indicates index mark detected from drive. This bit is an inverted copy of the 
IP input. 


SO BUSY 


When set command is in progress. When reset no command is in progress. 
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BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset, it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II 
and III Commands will not execute unless the drive is ready. 


S6 WRITE PROTECT 


On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a 
Write Protect. This bit is reset when updated. 


S5 RECORD TYPE/ 
WRITE FAULT 


On Read Record: It indicates the record-type code from data field address mark. 
1 = Deleted Data Mark. = Data Mark. On any Write: It indicates a Write Fault. This bit 
is reset when updated. 


S4 RECORD NOT 
FOUND (RNF) 


When set, it indicates that the desired track, sector, or side were not found. This bit is 
reset when updated. 


S3 CRC ERROR 


If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in 
data field. This bit is reset when updated. 


S2 LOST DATA 


When set, it indicates the computer did not respond to DRQ in one byte time. This bit is 
reset to zero when updated. 


S1 DATA REQUEST 


This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read 
Operation or the DR is empty on a Write operation. This bit is reset to zero when up- 
dated. 


SO BUSY 


When set, command is under execution. When reset, no command is under execution. 



ELECTRICAL CHARACTERISTICS 

Absolute Maximum Ratings 
Vdd with repect to Vss (ground): + 15 to - 0.3V 
Voltage to any input with respect to Vss = + 15 to 
Ice = 60 MA (35 MA nominal) 
Idd = 15 MA (10 MA nominal) 



Cin & Com = 15 pF max with all pins grounded except 
one under test. 
■ 0.3V Operating temperature = 0°C to 70°C 

Storage temperature = -55°Cto +125 C C 



OPERATING CHARACTERISTICS (DC) 

TA = 0°Cto70°C,VDD = + 12V ± .6V,Vss = OV.Vcc = + 5V ± .25V 



SYMBOL 


CHARACTERISTIC 


MIN. 


MAX. 


UNITS 


CONDITIONS 


!<L 


Input Leakage 




10 


MA 


Vin = Vdd** 


lOL 


Output Leakage 




10 


ma 


Vout = Vdd 


VlH 


Input High Voltage 


2.6 




V 




VlL 


Input Low Voltage 




0.8 


V 




VOH 


Output High Voltage 


2.8 




V 


lo= -100 M A 


Vol 


Output Low Voltage 




0.45 


V 


lo = 1.6 mA* 


Pd 


Power Dissipation 




0.6 


W 





*1792and1794l0 = 1.0 mA 

"Leakage conditions are for input pins without internal pull-up resistors. Pins 22, 23, 33, 36, and 37 have pull-up resistors. 
See Tech Memo #115 for testing procedures. 

See page 725 for ordering information. 
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INTRODUCTION 

Over the past several years, the Floppy Disk Drive has 
become the most popular on-line storage device for 
mini and microcomputer systems. Its fast access time, 
reliability and low cost-per-bit ratio enables the Floppy 
Disk Drive to be the solution in mass storage for mi- 
croprocessor systems. The drive interface to the Host 
system is standardized, allowing the OEM to substitute 
one drive for another with minimum hardware/ software 
modifications. 

Since Floppy Disk Data is stored and retrieved as a 
self-clocking serial data stream, some means of sep- 
arating the clock from the data and assembling this 
data in parallel form must be accomplished. Data is 
stored on individual Tracks of the media, requiring con- 
trol of a stepper motor to move the Read/Write head 
to a predetermined Track. Byte sychronization must 
also be accomplished to insure that the parallel data 
is properly assembled. After all the design considera- 
tions are met, the final controller can consist of 40 or 
more TTL packages. 

To alleviate the burden of Floppy Disk Controller de- 
sign, Western Digital has developed a Family of LSI 
Floppy Disk controller devices. Through its own set of 
macro commands, the FD179X Controller Family will 
perform all the functions necessary to read and write 
data to the drive. Both the 8" standard and 5 1 /4" mini- 
floppy are supported with single or double density re- 
cording techniques. The FD179X is compatible with 
the IBM 3740 (FM) data format, or the System 34 
(MFM) standards. Provisions for non-standard formats 
and variable sector lengths have been included to pro- 
vide more storage capability per track. Requiring stan- 
dard +5, + 12 power supplies the FD179X is available 
in a standard 40 pin dual-in-line package. 

The FD179X Family consists of 6 devices. The 
differences between these devices is summarized in 
Figure 1. The 1792 and 1794 are "single density only" 
devices, with the Double Density Enable pin (DDEN) 
left open by the user. Both True and inverted Data bus 
devices are available. Since the 179X can only drive 
one TTL Load, a true data bus system may use the 
1791 with external inverting buffers to arrive at a true 
bus scheme. The 1795 and 1797 are identical to the 
1791 and 1793, except a side select output has been 
added that is controlled through theCommand Register. 



SYSTEM DESIGN 

The first consideration in Floppy Disk Design is to de- 
termine which type of drive to use. The choice ranges 
from single-density single sided mini-floppy to the 8" 
double-density double-sided drive. Figure 2 illustrates 
the various drive and data capacities associated with 
each type. Although the 8" double-density drive offers 
twice as much storage, a more complex data separator 
and the addition of Write Precompensation circuits are 
mandatory for reliable data transfers. Whether to go 
with 8" double-density or not is dependent upon PC 
board space and the additional circuitry needed to ac- 
curately recover data with extreme bit shifts. The byte 
transfer time defines the nominal time required to 
transfer one byte of data from the drive. If the CPU 
used cannot service a byte in this time, then a DMA 
scheme will probably be required. The 179X also needs 
a few microseconds for overhead, which is subtracted 
from the transfer time. Figure 3 shows the actual ser- 
vice times that the CPU must provide on a byte-by-byte 
basis. If these times are not met, bytes of data will be 
lost during a read or write operation. For each byte 
transferred, the 179X generates a DRQ (Data Re- 
quest) signal on Pin 38. A bit is provided in the status 
register which is also set upon receipt of a byte from 
the Disk. The user has the option of reading the status 
register through program control or using the DRQ Line 
with DMA or interrupt schemes. When the data register 
is read, both the status register DRQ bit and the DRQ 
Line are automatically reset. The next full byte will 
again set the DRQ and the process continues until the 
sector(s) are read. The Write operation works exactly 
the same way, except a WRITE to the Data Register 
causes a reset of both DRQ's. 



RECORDING FORMATS 

The FD179X accepts data from the disk in a Fre- 
quency-Modulated (FM) or Modified-Frequency-Mod- 
ulated (MFM) Format. Shown in Figures 4A and 4B are 
both these Formats when writing a Hexidecimal byte 
of 'D2'. In the FM mode, the 8 bits of data are broken 
up into "bit cells." Each bit cell begins with a clock 
pulse and the center of the bit cell defines the data. If 
the data bit = 0, no pulse is written; if the data = 1, 
a pulse is written in the center of the cell. For the 8" 
drive, each clock is written 4 microseconds apart. 
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In the MFM mode, clocks are decoded into the data 
stream. The byte is again broken up into bit cells, with 
the data bit written in the center of the bit cell if data 
= 1 . Clocks are only written if both surrounding data 
bits are zero. Figure 4B shows that this occurs only 
once between Bit cell 4 and 5. Using this encoding 
scheme, pulses can occur 2, 3 or 4 microseconds 
apart. The bit cell time is now 2 microseconds; twice 
as much data can be recorded without increasing the 
Frequency rate due to this encoding scheme. 

The 1 79X was designed to be compatible with the IBM 
3740 (FM) and System 34 (MFM) Formats. Although 
most users do not have a need for data exchange with 
IBM mainframes, taking advantage of these well stud- 
ied formats will insure a high degree of system 
performance. The 179X will allow a change in gap 
fields and sector lengths to increase usable storage 
capacity, but variations away from these standards is 
not recommended. Both IBM standards are soft-sector 
format. Because of the wide variation in address marks, 
the 179X can only support soft-sectored media. Hard 
sectored diskettes have continued to lose popularity, 
mainly due to the unavailability of a standard and the 
limitation of sector lengths imposed by the physical 
sector holes in the diskette. 



PROCESSOR INTERFACE 

The Interface of the 179X to the CPU consists of an 
8-bit Bi-directional bus, read/write controls and optional 
interrupt lines. By selecting the device via the CHIP 
SELECT Line, each of the five internal registers can 
be accessed. 



Shown below are the registers and their addresses: 



PIN 3 


PIN 6 


PIN 5 


PIN 4 


PIN 2 


CS 


A, 


A 


RE=tf 


WE=*# 











STATUS REG 


COMMAND 








1 


TRACK REG 


REG 





1 





SECTOR REG 


TRACK REG 





1 


1 


DATA REG 


SECTOR REG 


1 


X 


X 


H1-Z 


DATA REG 
H1-Z 



The A), A,, Lines used for register selections can be 
configured at the CPU in a variety of ways. These lines 
may actually tie to CPU address lines, in which case 
the 179X will be memory-mapped and addressed like 
RAM. They may also be used under Program Control 
by tying to a port device such as the 8255, 6820, etc. 
As a diagnostic tool when checking out the CPU in- 
terface, the Track and Sector registers should respond 
like "RAM" when the 179X is idle (Busy = INTRQ = 
0). 

Because of internal synchronization cycles, certain 
time delays must be introduced when operating under 
Programmed I/O. The worst case delays are: 



OPERATION 


NEXT 
OPERATION 


DELAY REQ'D 


WRITE TO 
COMMAND REG 


READ STATUS 
REGISTER 


MFM = 14/xs* 
FM = 28/as. 


WRITE TO 
ANY REGISTER 


READ FROM A 
DIFFERENT REG 


NO DELAY 



*NOTE: Times Double when CLK = 1MHz {5Va" drive) 



Other CPU interface lines are CLK, MR and DDEN. 
The CLK line should be 2MHz (8" drive) or 1MHz (5 1 /»" 
drive) with a 50% duty cycle. Accuracy should be ±1% 
(crystal source) since all internal timing, including step- 
ping rates, are based upon this clock. 

The MR or Master Reset Line should be strobed a 
minimum of 50 microseconds upon each power-on 
condition. This line clears and initializes all internal reg- 
isters and issues a restore command (Hex '03') oh the 
rising edge. A quicker steppin g rat e can be written to 
the command register after a MR, in which case the 
remaining steps will occur at the faster programmed 
rate. The 179X will issue a maximu m of 25 5 stepping 
pulses in an attempt to expect the TROO line f o go 
active l ow. This line should be connected to the drive's 
TROO sensor. 

The DDEN line causes selection of either singl e den- 
sity (DDEN = 1) or double density operation. DDEN 
should not be switched during a read or write operation. 



Each time a command is issued to the 1 79X, the Busy 
bit is set and the INTRQ (Interrupt Request) Line is 
reset. The user has the option of checking the busy bit 
or use the INTRQ Line to denote command comple- 
tion. The Busy bit will be reset whenever the 179X is 
idle and awaiting a new command. The INTRQ Line, 
once set, can only be reset by a READ of the status 
register or issuing a new command. The MR (Master 
Reset) Line does not affect INTRQ. 
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FLOPPY DISK INTERFACE 

The Floppy Disk Interface can be divided into three 
sections: Motor Control, Write Signals and Read Sig- 
nals. All of these lines are capable of driving one TTL 
load and not compatible for direct connection to the 
drive. Most drives require an open-collector TTL inter- 
face with high current drive capability. This must be 
done on all outputs from the 179X. Inputs to the 179X 
may be buffered or tied to the Drives outputs, providing 
the appropriate resistor termination networks are used. 
Undershoot should not exceed -0.3 volts, while integ- 
rity of V IH and V 0H levels should be kept within spec. 

MOTOR CONTROL 

Motor Control is accomplished by the STEP and DIRC 
Lines. The STEP Line issues stepping pulses with a 
period defined by the rate field in all Type I commands. 
The DIRC Line defines the direction of steps (DIRC = 
1 STEP IN/DIRC = STEP OUT). 

Other Control Lines include thefp or Index Pulse. This 
Line is tied to the drives' Index L.E.D. sensor and 
makes an ac tive tra nsition for each revolution of the 
diskette. The TROO Line is another L.E.D. sensor that 
informs the 179X that the stepper motor is at its fur- 
thest position, over Track 00. The READY Line can be 
used for a number of functions, such as sensing "door 
open", Drive motor on, etc. Most drives provide a pro- 
grammable READY Signal selected by option jumpers 
on the drive. The 1 79X will look at the ready signal prior 
to executing READ/WRITE commands. READY is not 
inspected during any Type I commands. All Type I 
commands will execute regardless of the Logic Level 
on this Line. 

WRITE SIGNALS 

Writing of data is accomplished by the use of the WD, 
WG, WF, TG43, EARLY and LATE Lines. The WG or 
Write Gate Line is used to enable write current at the 
drive's R/W head. It is made active prior to writing data 
on the disk. The WF or WRITE FAULT Line is used to 
inform the 179X of a failure in drive electronics. This 
signal is multiplexed with the VFOE Line and must be 
logically separated if required. Figure 5 illustrates three 
methods of demultiplexing. 

The TG43 or "TRACK GREATER than 43" Line is 
used to decrease the Write current on the inner tracks, 
where bit densities are the highest. If not required on 
the drive, TG43 may be left open. 

WRITE PRECOMPENSATION 

The 179X provides three signals for double density 
Write Precompensation use. These signals are WRITE 
DATA, EARLY and LATE, When using single density 
drives (eighter 8" or 5 1 /4"), Write Precompensation is 
not necessary and the WRITE DATA line is generally 
TTL Buffered and sent directly to the drive. In this 
mode, EARLY and LATE are left open. 
For double density use, Write Precompensation is a 
function of the drive. Some manufacturers recommend 
Precompensating the 5 1 /»" drive, while others do not. 



With the 8" drive, Precompensation may be specified 
from TRACK 43 on, or in most cases, all TRACKS. If 
the recommended Precompensation is not specified, 
check with the manufacturer for the proper configura- 
tion required. 

The amount of Precompensation time also varies. A 
typical value will usually be specified from 100-300ns. 
Regardless of the parameters used, Write Precom- 
pensat ion must be done external to the 179X. When 
DDEN is tied low, EARLY or LATE will be activated at 
least 125ns. before and after the Write Data pulse. An 
Algorithm internal the 179X decides whether to raise 
EARLY or LATE, depending upon the previous bit pat- 
tern sent. As an example, suppose the recommended 
Precomp value has been specified at 1 50ns. The fol- 
lowing action should be taken: 



EARLY LATE 



ACTION TAKEN 



delay WD by 150ns (nominal) 

1 delay WD by 300ns (2X value) 
do not delay WD 



There are two methods of performing Write 
Precompensation: 

1) External Delay elements 

2) Digitally 

Shown in Figure 6 is a Precomp circuit using the West- 
ern Digital 2143 clock generator as the delay element. 
The WD pulse from the 179X creates a strobe to the 
2143, causing subsequent output pulses on the<€Tl,,02 
and J03 signals. The 5K Precomp adjust sets the de- 
sired Precomp value. Depending upon the condition of 
EARLY and LATE, J0C1 will be used for EARLY, j02 for 
nominal (EARLY = LATE = 0), andj03 for LATE. The 
use of "one-shots" or delay line in a Write Precom- 
pensation scheme offers the user the ability to vary the 
Precomp value. The J04 output resets the 74LS175 
Latch in anticipation of the next WD pulse. Figure 7 
shows the WD-EARLY/LATE relationship, while Figure 
8 shows the timing of this write Precomp scheme. 

Another method of Precomp is to perform the function 
digitally. Figure 9 illustrates a relationship between the 
WD pulse and the CLK pin, allowing a digital Precomp 
scheme. Figure 10 shows such a scheme with a pre- 
set Write Precompensation value of 250ns. The syn- 
chronous counter is used to generate 2MHz and 4MHz 
clock signals. The 2MHz clock is sent to the CLK input 
of the 179X and the 4MHz is used by the 4-bit shift 
register. When a WD pulse is not present, the 4MHz 
clock is shifting "ones" through the shift register and 
maintaining Q D at a zero level. When a WD pulse is 
present, a zero is loaded at either A, B, or C depending 
upon the states of LATE, EN PRECOMP and EARLY. 
The zero is then shifted by the 4MHz clock until it 
reaches the Q D output. The number of shift operations 
determines whether the WRITE DATA pulse is written 
early, nominal or late. If both FM and MFM operations 
is a system requirement, the output of this circuit should 
be disabled and the WD pulse should be sent directly 
to the drive. 
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DATA SEPARATION 

The 179X has two inputs (RAW READ & RCLK) and 
one output (VFOE) for use by an external data sepa- 
rator. The RAW READ input must present clock and 
data pulses to the 179X, while the RCLK input provides 
a "window" or strobe signal to clock each RAW READ 
pulse into the device. An ideal Data Separator would 
have the leading edge of the RAW READ pulse occur 
in the exact center of the RCLK strobe. 
Motor Speed Variation, Bit shifts and read amplifier 
recovery circuits all cause the RAW READ pulses to 
drift away from their nominal positions. As this occurs, 
the RAW READ pulses will shift left or right with re- 
spect to RCLK. Eventually, a pulse will make its tran- 
sition outside of its RCLK window, causing either a 
CRC error or a Record-not-Found error at the 179X. 

A Phase-Lock-Loop circuit is one method of achieving 
synchronization between the RCLK and RAW READ 
signals. As RAW READ pulses are fed to the PLL, 
minor adjustments of the free-running RCLK frequency 
can be made. If pulses are occurring too far apart, the 
RCLK frequency is decreased to keep synchroniza- 
tion. If pulses begin to occur closer together, RCLK is 
increased until this new higher frequency is achieved. 
In normal read operations, RCLK will be constantly 
adjusted in an attempt to match the incoming RAW 
READ frequency. 

Another method of Data Separation is the Counter- 
Separator technique. The RCLK signal is again free- 
running at a nominal rate, until a RAW READ pulse 
occurs. The Separator then denotes the position of the 
pulse with respect to RCLK (by the counter value), and 
counts down to increase or decrease the current RCLK 
window. The next RCLK window will occur at a nominal 
rate and will continue to run at this frequency until an- 
other RAW READ pulse adjusts RCLK, but only the 
present window is adjusted. 

Both PPL and Counter/Separator are acceptable 
methods of Data Separation. The PPL has the highest 
reliability because of its "tracking" capability and is rec- 
ommended for 8" double density designs. 

As a final note, the term "Data Separator" may be 
misleading, since the physical separation of clock and 
data bits are not actually performed. This term is used 
throughout the industry, and can better be described 
as a "Data Recovery Circuit" rather than a Data 
Separator. 

The VFOE signal is an output from the 179X that sig- 
nifies the head has been loaded and valid data pulses 
are appearing on the RAW READ line. It can be used 
to enable the Data Separator and to insure clean RCLK 
transitions to the 179X. Since some drives will output 
random pulses when the head is disengaged, VFOE 
can prevent an erratic RCLK signal during this time. If 
the Data Separator requires synchronization during a 
known pattern of one's or zero's, then RG (READ 
GATE) can be used. The RG signal will go active when 
the 179X is currently over a field of zeros or ones. RG 
is not available on the 1795/1797 devices, since this 
signal was replaced with the SSO (Side Select Output) 
Line. 



Shown in Figure 1 1 is a 2 1 /2 IC Counter/Separator. The 
74LS193 free runs at a frequency determined by the 
CRYCLK input. When a RAW READ pulse occurs, the 
counter is loaded with a starting count of '5'. When the 
RAW READ Line returns to a Logic 1, the counter 
counts down to zero and again free runs. The 74LS74 
insures a 50% duty cycle to the 1 79X and performs a 
divide-by-two of the Q D output. 

Figure 12 illustrates another Counter/Separator utiliz- 
ing a PROM as the count generator. Depending upon 
the RAW READ phase relationship to RCLK, the PROM 
is addressed and its data output is used as the counter 
value. A 16MHz clock is required for 8" double density, 
while an 8MHz clock can be used for single density. 
Figure 13 shows a Phase-Lock-Loop data recovery 
circuit. The phase detector (U2, Figure 2) compares 
the phase of the SHAPED DATA pulse to the phase 
of VFO CLK h- 2. If VFO CLK -=- 2 is lagging the 
SHAPED DATA pulse an output pulse on #9, U2 is 
generated. The filter/amplifier converts this pulse into 
a DC signal which increases the frequency of the VCO. 

If, correspondingly, CLK + 2 is leading the SHAPED 
DATA pulse, an output pulse on #5, U2 is generated. 
This pulse is converted into a DC signal which de- 
creases the frequency of the VCO. These two actions 
cause the VCO to track the frequency of the incoming 
READ DATA pulses. This correction process to keep 
the two signals in phase is constantly occurring because 
of spindle speed variation and circuit parameter 
variations. 

The operating specifications for this circuit are as 
follows: 



Free Running Frequency 


2MHz 


Capture Range 


± 15% 


Lock Up Time 


50 microsec. "1111" or 




"0000" Pattern 




100 Microsec "1010" Pat- 




tern 



The RAW READ pulses are generated from the falling 
edge of the SHAPED DATA pulses. The pulses are 
also reshaped to meet the 179X requirements. VFO 
CLK h- 2 OR 4 is divided by 2 once again to obtain 
VFO CLK OUT whose frequency is that required by the 
179X RCLK input. RCLK must be controlled by VFOE 
so VFOE is sampled on each rising edge of VFO CLK 
OUT. When VFOE goes active EN RCLK goes active 
•in synchronization with VFO CLK OUT preventing any 
glitches on the RCLK output. When VFOE goes inac- 
tive EN RCLK goes inactive in synchronization with 
VFO CLK OUT, again preventing any glitches on the 
RCLK output. 

Figure 14 illustrates a PPL data recovery circuit using 
the Western Digital 1691 Floppy Support device. Both 
data recovery and Write Precomp Logic is contained 
within the 1691, allowing low chip count and PLL re- 
liability. The 74S124 supplies the free-running VCO 
output. The PUMP UP and PUMP DOWN signals from 
the 1691 are used to control the 74S124's frequency. 
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COMMAND USAGE 

Whenever a command is successfully or unsuccess- 
fully completed, the busy bit of the status register is 
reset and the INTRQ line is forced high. Command ter- 
mination may be detected either way. The INTRQ can 
be tied to the host processor's interrupt with an appro- 
priate service routine to terminate commands. The 
busy bit may be monitored with a user program and 
will achieve the same results through software. Per- 
forming both an INTRQ and a busy bit check is not 
recommended because a read of the status register to 
determine the condition of the busy bit will reset the 
INTRQ line. This can cause an INTRQ from not 
occurring. 

RESTORE COMMAND 

On some disk drives, it is possible to position the R/W 
head outward past Track 00 and prevent the TROO 
line from going low unless a STEP IN is first performed. 
If this condition exists in the drive used, the RESTORE 
command will never detect a TROO. Issuing several 
STEP IN pulses before a RESTORE command will 
remedy this situation. The RESTORE and all other 
Type I commands will execute even though the READY 
bit indicates the drive is not ready (NOT READY = 1). 

READ TRACK COMMAND 

The READ TRACK command can be used to manually 
inspect data on a hard copy printout. Gaps, address 
marks and all data are brought in to the data register 
during this command. The READ TRACK command 
may be used to inspect diskettes for valid formatting 
and data fields as well as address marks. Since the 
179X does not synchronize clock and data until the In- 
dex Address Mark is detected, data previous to this ID 
mark will not be valid. READ GATE (RG) is not ac- 
tuated during this command. 

READ ADDRESS COMMAND 

In systems that use either multiple drives or sides, the 
read address command can be used to tell the host 
processor which drive or side is selected. The current 
position of the R/W head is also denoted in the six 
bytes of data that are sent to the computer. 



TRACK SIDE 


SECTOR 


CRS 
LENGTH 


CRC 
1 


CRC 
2 



The READ ADDRESS command as well as all other 
Type II and Type III commands will not execute if the 
READY line, is inactive (READY = 0). Instead, an in- 
terrupt will be generated and the NOT READY status 
bit will be se,t to a 1 . 



FORCED INTERRUPT COMMAND 

The Forced Interrupt command is generally used to 
terminate a multiple sector command or to insure Type 
I status in the status register. The lower four bits of the 
command determine the conditional interrupt as follows: 



1 = NOT-READY TO READY TRANSITION 
1, = READY TO NOT-READY TRANSITION 

1 2 = EVERY INDEX PULSE 

1 3 = IMMEDIATE INTERRUPT 



Regardless of the conditional interrupt set, any com- 
mand that is currently being executed when the Forced 
Interrupt command is loaded will immediately be ter- 
minated and the busy bit will be reset indicating an idle 
condition. 

Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified 
has occurred. 

The conditional interrupt is enabled when the corre- 
sponding bit positions of the command (l 3 -l ) are set 
to a 1 . If l 3 -l are all set to zero, no interrupt will occur, 
but any command presently under execution will be 
immediately terminated upon receipt of the Force In- 
terrupt command (HEX DO). 
As usual, to clear the interrupt a read of the status reg- 
ister or a write to the command register is required. 
The exception is when using the immediate interrupt 
condition (l 3 = 1). If this command is loaded into the 
command register, an interrupt will be immediately 
generated and the current command terminated. 
Reading the status or writing to the command register 
will not automatically clear the interrupt; another forced 
interrupt command with l 3 -l = must be loaded jnto 
the command register in order to reset the INTRQ from 
this condition. 

More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (I, = 
1) and the Every Index Pulse (l 2 = 1) are both set, the 
resultant command would be HEX "DA". The "OR" 
function is performed so that either a READY TO NOT- 
READY or the next Index Pulse will cause an interrupt 
condition. 

DATA RECOVERY 

Occasionally, the R/W head of the disk drive may get 
"off track", and dust or dirt may get trapped on the 
media. Both of these conditions will cause a RECORD 
NOT FOUND and/or a CRC error to occur. This "soft 
error" can usually be recovered by the following 
procedure: 

1 . Issue the command again 

2. Unload and load the head and repeat step 

3. Issue a restore, seek the track, and repeat step 1 



D 
CO 



If RNF or CRC errors are still occurring after trying 
these methods, a "hard error" may exist. This is usu- 
ally caused by improper disk handling, exposure to 
high magnetic fields, etc. and generally results in de- 
stroying portions or tracks of the diskette. 
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2 FIGURE 1. DEVICE CHARACTERISTICS 

CO 



DEVICE 


SNGL DENSITY 


DBLE DENSITY 


INVERTED BUS 


TRUE BUS 


DOUBLE-SIDED 


1791 


X 


X 


X 






1792 


X 




X 






1793 


X 


X 




X 




1794 


X 






X 




1795 


X 


X 


X 




X 


1797 


X 


X 




X 


X 



FIGURE 2. STORAGE CAPACITIES 









UNFORMATTED 




FORMATTED 


SIZE 


DENSITY 


SIDES 


CAPACITY (NOMINAL) 


BYTE 

TRANSFER 

TIME 


CAPACITY 


PER TRACK 


PER DISK 


PER TRACK 


PER DISK 


5W 


SINGLE 


1 


3125 


109,375* 


64,u,s 


2304" 


80,640 


5V4" 


DOUBLE 


1 


6250 


218,750 


32/ts 


4608*** 


161,280 


5 1 /4" 


SINGLE 


2 


3125 


218,750 


64/as 


2304 


161,280 


5 1 /4" 


DOUBLE 


2 


6250 


437,500 


32/lis 


4608 


322,560 


8" 


SINGLE 


1 


5208 


401,016 


32/is 


3328 


256,256 


8" 


DOUBLE 


1 


10,416 


802,032 


16^s 


6656 


512,512 


8" 


SINGLE 


2 


5208 


802,032 


32jas 


3328 


512,512 


8" 


DOUBLE 


2 


10,416 


1,604,064 


16/is 


6656 


1,025,024 



*Based on 35 Tracks/Side 

* Based on 18 Sectors/Track (128 byte/sec) 

*Based on 18 Sectors/Track (256 bytes/sec) 
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FIGURE 3. NOMINAL VS. WORSE CASE SERVICE TIME 



SIZE 


DENSITY 


NOMINAL TRANSFER 
TIME 


WORST-CASE 179X SERVICE TIME 


READ 


WRITE 


5V4" 
5V4" 
8" 
8" 


SINGLE 
DOUBLE 
SINGLE 
DOUBLE 


64/LiS 
32/iS 
32/xs 
16/iS 


55.0/xs 
27.5/is 
27.5/iS 
13.5/u,s 


47.0/iS 
23.5/is 
23.5/iS 
11.5/is 



8 



FIGURE 4A. FM RECORDING 


















4ms 








BITO 


BIT1 




BIT 2 


BIT 3 


BIT 4 


BIT 5 


BIT 6 


BIT 7 




HEX , , 
D2' 





10 10 


Fl R Fl R I 


3 


I 


^LFLfl R FLRJ 


H 




RULE: 

1) WRITE DATA BITS AT CENTER 
OF BIT CELL IF A "1" 










2) WRITE CLOCK BITS AT LEADING 
EDGE OF THE BIT CELL 







FIGURE 4B. MFM RECORDING 



2fxs 








i 








BITO 


BIT1 


BIT 2 


BIT 3 


BIT 4 


| 


BIT 5 


BIT 6 


BIT 7 




1 1 


1 










1 


° 


H n E , X R R 


R 




R 




ra 




RULE: 














1) WRITE DATA BITS AT CENTER 
OF BIT CELL IF A "1" 














2) WRITE CLOCK BITS AT LEADING 
EDGE OF BIT CELL IF: 














A) NO DATA BIT HAS BEEN WRITTEN LAST 
— AND— 

B) NO DATA BIT WILL BE WRITTEN NEXT 
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FIGURE 5. WF/VFOE DEMULTIPLEXING CIRCUITRY 



T1 

O 

CO 

X 



{>-* 



KZfh-^ 



(WG TO DRIVE) 
(WF FROM DRIVE) 



PIN 33 USED AS A VFOE SIGNAL ONLY 



5>™ 



• PIN 33 USED AS VFOE AND WF SIGNALS 



T-J-^O^ 



WF (FROM DRIVE) 
H> WG (TO DRIVE) 



• PIN 33 USED AS A WF SIGNAL ONLY 



EARLY 
LATE 



:_I> 4 7 



7 C-LATE 



15 C-NOMINAL 



+ 12 > • W 



5K 

PRECOMP. 
ADJUST 



IN JBl 



jBPW 






WD TO 
DRIVE 



FIGURE 6. 179X WRITE PRE-COMP 
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-< 2. 3, Vs. ± CLK TOL >■ 



n 



EARLY 
OR LATE 



-*\ 



ft 

JtTL 



a 



2. 4/iS ± CLK TOL ». 

[«*- 500 NS ± 50 



EARLY 
OR LATE 




DOUBLE TIMES FOR 5" (MINI-ROPPY) 



UIbJ 



DOUBLE TIMES FOR 5" (MINI-FLOPPY) 



125 NS MIN. VALID 
FOR DURATION OF 
WD PULSE 



WRITE PRE-COMP TIMING FOR MFM 



VALID BEFORE LEADING EDGE OF WD 



WRITE PRE-COMP TIMING FOR FM 



a 
x 



FIGURE 7. WRITE PRE-COMP TIMING 



BIT CELLO I BIT CELL 1 I BIT CELL 2 I BIT CELL 3 I BIT CELL 4 I BIT CELL 5 I BIT CELL 6 I BIT CELL 7 I BIT CELL 8 I BIT CELL 9 

/ ■ ! / I • I * li li I ? 1/ < /i I 4 

I f"«-200NS 

1_fl P >m \Su B H n b a 



WCz. 
CO 

EARLY 

LATE 

3-EARLY 

C-LATE 



123NS|-| -» 



n 



rr 



j~i 



J~L 



r~L 



C-NOMINAL I I I I 

*_- n n 




H~tf 



u — u — LT~ 
id — y ti — 



FIGURE 8. PRECOMP TIMING FOR CIRCUIT IN FIGURE 6 



riMM««lBUJUJ«UW«*^»,^ 



47 



Western Digital Data Sheet 



■n 
o 

CO 

X 



CLK 
@1MHz 



WD 
(DDEN = 0) 





jTN 



»100ns alOOns 



CLK 
@2MHz 



WD 
(DDEN = 0) 




m 




FIGURE 9. WD/CLK RELATIONSHIP FOR WRITE PRECOMP USE 



8 MHz D- 



1K1) 
+5 O-^VVW- 



WB 

(FROM 1791) Q- 



TQ43 (EN PRECOMP) 







~^h-^~ 



CLK 
CTB 

D 

shft/lTT 




-O 2MHz 
(TO 1791) 



WRITE 
DATE 
(TO DRIVE) 



FIGURE 10. DIGITAL WRITE PRECOMP CIRCUIT 

(PROVIDED COURTESY OF MPI. OKLAHOMA CITY, OK 73112 



48 



Western Digital Data Sheet 



-n 

O 

to 



RAW READ > 1 " "\ 

FROM DRIVE 1 



£ 



C 

H 



R. 0- 150NS±50 



► 5 > f 



IT 



LD 

A 

e Q„ 

C 

cu 

CD c 



-<+5 



A 

CRYCLK 



TYPE 


DDEN 


CRYCLK 




8-FM 


1 


8 MHz 


5"MFM 





8 MHz 


5"FM 


1 


4 MHz 



RG 
DDEN 



FIGURE 11. COUNTER/SEPARATOR 
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03 
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04 
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05 
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06 


05 




07 
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08 


OB 
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09 


OD 




OA 
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OB 


OE 




OC 


OF 




OD 


OF 
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OF 
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10 


01 
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11 
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09 




19 


OA 




1A 


OB 




1B 


OC 




1C 


OD 




1D 


OE 




1E 


OF 




1F 


00 





READ DATA 
FROM >- 
DRIVE 



^> 















































> 


<10 

r K 

•""1 1 1 33 












74LS04 

27 








16 MHz 
CLOCK 


74LS08 
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12 
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CS 
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2 10 
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FIGURE 12. 179X DATA SEPARATOR 

(PROVIDED COURTESY OF ANDROMEDA SYSTEMS. PANORAMA CITY, CA 91402) 
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FIGURE 13. PLL DATA RECOVERY CIRCUIT 

(PROVIDED COURTESY OF MPI. OKLAHOMA CITY. OK 73112) 
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NOTE 3 



17 



+ 12V 



1) ALL RESISTORS 'AW ± 5% 

2. SPECIFICATIONS = 
CAPTURE RANGE: ±20% 
LOCK-UP TIME: 25mS6C 

(ALL ONE'S PATTERN, MFM) 

3) FOR 5 1/4" 8 



04 03 02 01 
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FIGURE 14. 8" SINGLE/DOUBLE DENSITY SYSTEM 
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DiskMaster Schematic 
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APPENDIX C. SPECIFICATIONS 



IEEE-696 Standard (S-100) 



Fully compatible with the 
IEEE-696 specifications. 



Controller Chip 



Uses the Western Digital 1793 
controller for reliability and 
high performance. 



I/O Mapped 



Saves memory space over memory 
mapped options. 



User Options 

Port Address Switch 

interrupt Option 

Wait-State Jumper 

DMA Prioritizing 
Drive Motor Control 



Write Precompensa- 
tion Control 

Fast Seek Option 



Head Load Option 



Configuration DIP 
Header 



Configurable to any 8-port 
group within a 256-port 
address range. 

Configurable to any of the 
IEEE-696 hardware interrupt 
lines. 

Allows automatic insertion of 
wait states when used with 
high-speed CPU boards. 

For compatibility with other 
DMA devices in the system. 

For both 8-inch and 5.25-inch 
disk drives. 

Either under software or 
hardware control. 

For use with voice coil head 
positioner. 

Configurable for older full- 
height 8-inch drives, or the 
new half-height drives. 

For adapting to various pinout 
designations of 8-inch drives. 



Noise Margins 



All signal inputs to the board 
have a minimum of 0.4V 
hysteresis at 25°C. 
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Power Requirements 



+ 8V at 1.6A; +16V at 90 mA (at 
250c) 



Operating Environments 



0°C to 70 U C. 



Reliability 



The DiskMaster board has been 
in production for about one 
year. The demonstrated 
performance to date indicates 
that a reliability rate in 
excess of 98% will be typical. 
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90-DAY LIMITED WARRANTY 



WARRANTY AED WARRANTY PERIOD 

When sold by Seattle Computer Products (hereinafter referred to as SCP) or through 
an authorized SCP dealer, this product is warranted to the original purchaser and 
all subsequent owners of the product for a period of 90 days from the time the 
product is first sold at retail and for such additional time as the product may be 
out of the owner's possession for the purpose of receiving warranty service at the 
factory. When sold to the end-user by an OEM, the warranty terms vary. Consult 
your OEM for specific warranty coverage. 

WARRANTY COVERAGE 

This product is warranted to be free from defects of material and workmanship and to 
perform within its specifications as detailed in the instruction or operating manual 
during the period of the warranty. This warranty does not cover damage and is void 
if the product has been damaged by neglect, accident, unreasonable use, improper 
repair, or other causes not arising out of defects in material or workmanship. 

WARRANTY PERFORMANCE 

During the warranty period, SCP will repair or replace defective boards or products 
or components of boards or products upon written notice that a defect exists. 
Certain high value parts may have to be returned to SCP prior to replacement. Other 
components will be replaced without the part having to be returned to the factory 
with the exception that SCP retains the right in all cases to examine the defective 
board or other products prior to the item's replacement under the warranty. In the 
event the return of the board, product, or component is requested by SCP under this 
warranty, the owner shall ship the item prepaid to the SCP factory. SCP will pay 
for shipment of replacement items back to the owner. All repairs or replacements 
under this warranty will be performed by SCP within five working days of receipt of 
notice of defect or return of components as called for under this warranty. 

WARRANTY DISCLAIMERS 

While high reliability was a major design factor for this product and care was used 
in its manufacture, no certainty can be achieved that any particular product will 
operate correctly for any specific time. No representation is made by SCP that this 
product will not fail in normal use. Because of the inability to guarantee 100% 
reliability, SCP shall not be liable for any consequential damage the user may 
suffer because the product fails to function reliably 100% of the time. Any implied 
warranties arising from the sale of this product are limited in duration to the 
warranty period defined above. 

LEGAL REMEDIES 

This warranty gives the purchaser specific legal rights. He may have additional 
rights which vary from state to state. 

SHIPPING INSTRUCTIONS 

In the event it becomes necessary to return the product or component to SCP: 

1. Telephone (206) 575-1830 to obtain an RMA number. No products will accepted by 
SCP without an RMA number. 

2. Package the product in a crushproof container with adequate packing material to 
prevent damage. 

3. Return the product along with proof of purchase and a written explanation of 
the difficulty encountered along with your name, address, and phone number. 
Send the product to Seattle Computer Products, 1114 Industry Drive, Seattle WA 
98188. 



Comment Form 



I 
I 
I 

I 

c Use this form to comment on this product and to report 

<■*" errors in the manual. 

p, 

o 

_j System Description: 

p. CPU: Manufacturer ; Model No.! 

Memory: Manufacturer Model No.__ 

Memory Size 



Disk 

Controller: Manufacturer Model No. 

I/O 

Interfaces: Manufacturer Model No. 

Other 



Comments : 



Name ' Company 

Street 



City . ■ State Zip 

Phone Date 



o 

c 

O 
H 



Fold and tape 



Place 
stamp 
here 



Seattle Computer Products 
1114 Industry Drive 
Seattle, WA 98188 

Attention: Hardware Support 



Fold and tape 



